annotate src/quickfix.c @ 15720:600c2a9024a2

Added tag v8.1.0867 for changeset 3f92851b9a57ea4bca365d4ebab94b88cd4b8349
author Bram Moolenaar <Bram@vim.org>
date Fri, 01 Feb 2019 22:15:13 +0100
parents b8a2362073bb
children 2fe4a503c5ad
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10042
4aead6a9b7a9 commit https://github.com/vim/vim/commit/edf3f97ae2af024708ebb4ac614227327033ca47
Christian Brabandt <cb@256bit.org>
parents: 9982
diff changeset
1 /* vi:set ts=8 sts=4 sw=4 noet:
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2 *
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3 * VIM - Vi IMproved by Bram Moolenaar
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4 *
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5 * Do ":help uganda" in Vim to read copying and usage conditions.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
6 * Do ":help credits" in Vim to see a list of people who contributed.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7 * See README.txt for an overview of the Vim source code.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
8 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
9
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
10 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
11 * quickfix.c: functions for quickfix mode, using a file with error messages
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
12 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
13
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
14 #include "vim.h"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
15
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
16 #if defined(FEAT_QUICKFIX) || defined(PROTO)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
17
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
18 struct dir_stack_T
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
19 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
20 struct dir_stack_T *next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
21 char_u *dirname;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
22 };
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
23
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
24 /*
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
25 * For each error the next struct is allocated and linked in a list.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
26 */
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
27 typedef struct qfline_S qfline_T;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
28 struct qfline_S
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
29 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
30 qfline_T *qf_next; // pointer to next error in the list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
31 qfline_T *qf_prev; // pointer to previous error in the list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
32 linenr_T qf_lnum; // line number where the error occurred
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
33 int qf_fnum; // file number for the line
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
34 int qf_col; // column where the error occurred
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
35 int qf_nr; // error number
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
36 char_u *qf_module; // module name for this error
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
37 char_u *qf_pattern; // search pattern for the error
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
38 char_u *qf_text; // description of the error
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
39 char_u qf_viscol; // set to TRUE if qf_col is screen column
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
40 char_u qf_cleared; // set to TRUE if line has been deleted
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
41 char_u qf_type; // type of the error (mostly 'E'); 1 for
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
42 // :helpgrep
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
43 char_u qf_valid; // valid error message detected
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
44 };
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
45
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
46 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
47 * There is a stack of error lists.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
48 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
49 #define LISTCOUNT 10
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
50 #define INVALID_QFIDX (-1)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
51
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
52 /*
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
53 * Quickfix list type.
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
54 */
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
55 typedef enum
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
56 {
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
57 QFLT_QUICKFIX, // Quickfix list - global list
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
58 QFLT_LOCATION, // Location list - per window list
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
59 QFLT_INTERNAL // Internal - Temporary list used by getqflist()/getloclist()
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
60 } qfltype_T;
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
61
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
62 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
63 * Quickfix/Location list definition
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
64 * Contains a list of entries (qfline_T). qf_start points to the first entry
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
65 * and qf_last points to the last entry. qf_count contains the list size.
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
66 *
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
67 * Usually the list contains one or more entries. But an empty list can be
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
68 * created using setqflist()/setloclist() with a title and/or user context
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
69 * information and entries can be added later using setqflist()/setloclist().
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
70 */
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
71 typedef struct qf_list_S
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
72 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
73 int_u qf_id; // Unique identifier for this list
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
74 qfltype_T qfl_type;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
75 qfline_T *qf_start; // pointer to the first error
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
76 qfline_T *qf_last; // pointer to the last error
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
77 qfline_T *qf_ptr; // pointer to the current error
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
78 int qf_count; // number of errors (0 means empty list)
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
79 int qf_index; // current index in the error list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
80 int qf_nonevalid; // TRUE if not a single valid entry found
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
81 char_u *qf_title; // title derived from the command that created
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
82 // the error list or set by setqflist
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
83 typval_T *qf_ctx; // context set by setqflist/setloclist
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
84
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
85 struct dir_stack_T *qf_dir_stack;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
86 char_u *qf_directory;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
87 struct dir_stack_T *qf_file_stack;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
88 char_u *qf_currfile;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
89 int qf_multiline;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
90 int qf_multiignore;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
91 int qf_multiscan;
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
92 long qf_changedtick;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
93 } qf_list_T;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
94
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
95 /*
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
96 * Quickfix/Location list stack definition
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
97 * Contains a list of quickfix/location lists (qf_list_T)
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
98 */
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
99 struct qf_info_S
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
100 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
101 // Count of references to this list. Used only for location lists.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
102 // When a location list window reference this list, qf_refcount
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
103 // will be 2. Otherwise, qf_refcount will be 1. When qf_refcount
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
104 // reaches 0, the list is freed.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
105 int qf_refcount;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
106 int qf_listcount; // current number of lists
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
107 int qf_curlist; // current error list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
108 qf_list_T qf_lists[LISTCOUNT];
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
109 qfltype_T qfl_type; // type of list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
110 };
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
111
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
112 static qf_info_T ql_info; // global quickfix list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
113 static int_u last_qf_id = 0; // Last used quickfix list id
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
114
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
115 #define FMT_PATTERNS 11 // maximum number of % recognized
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
116
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
117 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
118 * Structure used to hold the info of one part of 'errorformat'
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
119 */
789
b29b006d52d2 updated for version 7.0230
vimboss
parents: 729
diff changeset
120 typedef struct efm_S efm_T;
b29b006d52d2 updated for version 7.0230
vimboss
parents: 729
diff changeset
121 struct efm_S
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
122 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
123 regprog_T *prog; // pre-formatted part of 'errorformat'
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
124 efm_T *next; // pointer to next (NULL if last)
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
125 char_u addr[FMT_PATTERNS]; // indices of used % patterns
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
126 char_u prefix; // prefix of this format line:
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
127 // 'D' enter directory
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
128 // 'X' leave directory
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
129 // 'A' start of multi-line message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
130 // 'E' error message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
131 // 'W' warning message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
132 // 'I' informational message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
133 // 'C' continuation line
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
134 // 'Z' end of multi-line message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
135 // 'G' general, unspecific message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
136 // 'P' push file (partial) message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
137 // 'Q' pop/quit file (partial) message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
138 // 'O' overread (partial) message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
139 char_u flags; // additional flags given in prefix
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
140 // '-' do not include this line
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
141 // '+' include whole line in message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
142 int conthere; // %> used
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
143 };
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
144
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
145 // List of location lists to be deleted.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
146 // Used to delay the deletion of locations lists by autocmds.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
147 typedef struct qf_delq_S
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
148 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
149 struct qf_delq_S *next;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
150 qf_info_T *qi;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
151 } qf_delq_T;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
152 static qf_delq_T *qf_delq_head = NULL;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
153
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
154 // Counter to prevent autocmds from freeing up location lists when they are
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
155 // still being used.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
156 static int quickfix_busy = 0;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
157
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
158 static efm_T *fmt_start = NULL; // cached across qf_parse_line() calls
10367
4e4e116e3689 commit https://github.com/vim/vim/commit/63bed3d319b5d90765dbdae93a3579b6322d79fb
Christian Brabandt <cb@256bit.org>
parents: 10359
diff changeset
159
7805
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
160 static void qf_new_list(qf_info_T *qi, char_u *qf_title);
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
161 static int qf_add_entry(qf_info_T *qi, int qf_idx, char_u *dir, char_u *fname, char_u *module, int bufnum, char_u *mesg, long lnum, int col, int vis_col, char_u *pattern, int nr, int type, int valid);
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
162 static void qf_free(qf_list_T *qfl);
7805
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
163 static char_u *qf_types(int, int);
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
164 static int qf_get_fnum(qf_info_T *qi, int qf_idx, char_u *, char_u *);
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
165 static char_u *qf_push_dir(char_u *, struct dir_stack_T **, int is_file_stack);
7805
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
166 static char_u *qf_pop_dir(struct dir_stack_T **);
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
167 static char_u *qf_guess_filepath(qf_list_T *qfl, char_u *);
7805
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
168 static void qf_fmt_text(char_u *text, char_u *buf, int bufsize);
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
169 static int qf_win_pos_update(qf_info_T *qi, int old_qf_index);
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
170 static win_T *qf_find_win(qf_info_T *qi);
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
171 static buf_T *qf_find_buf(qf_info_T *qi);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
172 static void qf_update_buffer(qf_info_T *qi, qfline_T *old_last);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
173 static void qf_fill_buffer(qf_info_T *qi, buf_T *buf, qfline_T *old_last);
7805
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
174 static buf_T *load_dummy_buffer(char_u *fname, char_u *dirname_start, char_u *resulting_dir);
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
175 static void wipe_dummy_buffer(buf_T *buf, char_u *dirname_start);
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
176 static void unload_dummy_buffer(buf_T *buf, char_u *dirname_start);
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
177 static qf_info_T *ll_get_or_alloc_list(win_T *);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
178
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
179 // Quickfix window check helper macro
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
180 #define IS_QF_WINDOW(wp) (bt_quickfix(wp->w_buffer) && wp->w_llist_ref == NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
181 // Location list window check helper macro
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
182 #define IS_LL_WINDOW(wp) (bt_quickfix(wp->w_buffer) && wp->w_llist_ref != NULL)
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
183
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
184 // Quickfix and location list stack check helper macros
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
185 #define IS_QF_STACK(qi) (qi->qfl_type == QFLT_QUICKFIX)
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
186 #define IS_LL_STACK(qi) (qi->qfl_type == QFLT_LOCATION)
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
187 #define IS_QF_LIST(qfl) (qfl->qfl_type == QFLT_QUICKFIX)
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
188 #define IS_LL_LIST(qfl) (qfl->qfl_type == QFLT_LOCATION)
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
189
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
190 /*
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
191 * Return location list for window 'wp'
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
192 * For location list window, return the referenced location list
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
193 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
194 #define GET_LOC_LIST(wp) (IS_LL_WINDOW(wp) ? wp->w_llist_ref : wp->w_llist)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
195
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
196 /*
11443
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
197 * Looking up a buffer can be slow if there are many. Remember the last one
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
198 * to make this a lot faster if there are multiple matches in the same file.
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
199 */
11447
698ee9d4fe9f patch 8.0.0607: after :bwipe + :new bufref might still be valid
Christian Brabandt <cb@256bit.org>
parents: 11445
diff changeset
200 static char_u *qf_last_bufname = NULL;
698ee9d4fe9f patch 8.0.0607: after :bwipe + :new bufref might still be valid
Christian Brabandt <cb@256bit.org>
parents: 11445
diff changeset
201 static bufref_T qf_last_bufref = {NULL, 0, 0};
11443
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
202
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
203 static char *e_loc_list_changed =
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
204 N_("E926: Current location list was changed");
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
205
11443
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
206 /*
9033
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
207 * Maximum number of bytes allowed per line while reading a errorfile.
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
208 */
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
209 #define LINE_MAXLEN 4096
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
210
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
211 static struct fmtpattern
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
212 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
213 char_u convchar;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
214 char *pattern;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
215 } fmt_pat[FMT_PATTERNS] =
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
216 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
217 {'f', ".\\+"}, // only used when at end
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
218 {'n', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
219 {'l', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
220 {'c', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
221 {'t', "."},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
222 {'m', ".\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
223 {'r', ".*"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
224 {'p', "[- .]*"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
225 {'v', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
226 {'s', ".\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
227 {'o', ".\\+"}
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
228 };
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
229
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
230 /*
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
231 * Convert an errorformat pattern to a regular expression pattern.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
232 * See fmt_pat definition above for the list of supported patterns. The
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
233 * pattern specifier is supplied in "efmpat". The converted pattern is stored
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
234 * in "regpat". Returns a pointer to the location after the pattern.
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
235 */
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
236 static char_u *
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
237 efmpat_to_regpat(
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
238 char_u *efmpat,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
239 char_u *regpat,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
240 efm_T *efminfo,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
241 int idx,
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
242 int round)
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
243 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
244 char_u *srcptr;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
245
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
246 if (efminfo->addr[idx])
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
247 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
248 // Each errorformat pattern can occur only once
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
249 semsg(_("E372: Too many %%%c in format string"), *efmpat);
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
250 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
251 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
252 if ((idx && idx < 6
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
253 && vim_strchr((char_u *)"DXOPQ", efminfo->prefix) != NULL)
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
254 || (idx == 6
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
255 && vim_strchr((char_u *)"OPQ", efminfo->prefix) == NULL))
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
256 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
257 semsg(_("E373: Unexpected %%%c in format string"), *efmpat);
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
258 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
259 }
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
260 efminfo->addr[idx] = (char_u)++round;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
261 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
262 *regpat++ = '(';
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
263 #ifdef BACKSLASH_IN_FILENAME
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
264 if (*efmpat == 'f')
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
265 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
266 // Also match "c:" in the file name, even when
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
267 // checking for a colon next: "%f:".
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
268 // "\%(\a:\)\="
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
269 STRCPY(regpat, "\\%(\\a:\\)\\=");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
270 regpat += 10;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
271 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
272 #endif
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
273 if (*efmpat == 'f' && efmpat[1] != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
274 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
275 if (efmpat[1] != '\\' && efmpat[1] != '%')
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
276 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
277 // A file name may contain spaces, but this isn't
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
278 // in "\f". For "%f:%l:%m" there may be a ":" in
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
279 // the file name. Use ".\{-1,}x" instead (x is
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
280 // the next character), the requirement that :999:
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
281 // follows should work.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
282 STRCPY(regpat, ".\\{-1,}");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
283 regpat += 7;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
284 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
285 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
286 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
287 // File name followed by '\\' or '%': include as
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
288 // many file name chars as possible.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
289 STRCPY(regpat, "\\f\\+");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
290 regpat += 4;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
291 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
292 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
293 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
294 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
295 srcptr = (char_u *)fmt_pat[idx].pattern;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
296 while ((*regpat = *srcptr++) != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
297 ++regpat;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
298 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
299 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
300 *regpat++ = ')';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
301
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
302 return regpat;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
303 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
304
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
305 /*
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
306 * Convert a scanf like format in 'errorformat' to a regular expression.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
307 * Returns a pointer to the location after the pattern.
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
308 */
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
309 static char_u *
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
310 scanf_fmt_to_regpat(
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
311 char_u **pefmp,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
312 char_u *efm,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
313 int len,
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
314 char_u *regpat)
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
315 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
316 char_u *efmp = *pefmp;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
317
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
318 if (*efmp == '[' || *efmp == '\\')
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
319 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
320 if ((*regpat++ = *efmp) == '[') // %*[^a-z0-9] etc.
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
321 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
322 if (efmp[1] == '^')
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
323 *regpat++ = *++efmp;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
324 if (efmp < efm + len)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
325 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
326 *regpat++ = *++efmp; // could be ']'
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
327 while (efmp < efm + len
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
328 && (*regpat++ = *++efmp) != ']')
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
329 // skip ;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
330 if (efmp == efm + len)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
331 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
332 emsg(_("E374: Missing ] in format string"));
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
333 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
334 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
335 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
336 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
337 else if (efmp < efm + len) // %*\D, %*\s etc.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
338 *regpat++ = *++efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
339 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
340 *regpat++ = '+';
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
341 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
342 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
343 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
344 // TODO: scanf()-like: %*ud, %*3c, %*f, ... ?
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
345 semsg(_("E375: Unsupported %%%c in format string"), *efmp);
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
346 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
347 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
348
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
349 *pefmp = efmp;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
350
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
351 return regpat;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
352 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
353
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
354 /*
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
355 * Analyze/parse an errorformat prefix.
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
356 */
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
357 static char_u *
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
358 efm_analyze_prefix(char_u *efmp, efm_T *efminfo)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
359 {
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
360 if (vim_strchr((char_u *)"+-", *efmp) != NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
361 efminfo->flags = *efmp++;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
362 if (vim_strchr((char_u *)"DXAEWICZGOPQ", *efmp) != NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
363 efminfo->prefix = *efmp;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
364 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
365 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
366 semsg(_("E376: Invalid %%%c in format string prefix"), *efmp);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
367 return NULL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
368 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
369
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
370 return efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
371 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
372
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
373 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
374 * Converts a 'errorformat' string part in 'efm' to a regular expression
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
375 * pattern. The resulting regex pattern is returned in "regpat". Additional
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
376 * information about the 'erroformat' pattern is returned in "fmt_ptr".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
377 * Returns OK or FAIL.
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
378 */
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
379 static int
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
380 efm_to_regpat(
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
381 char_u *efm,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
382 int len,
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
383 efm_T *fmt_ptr,
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
384 char_u *regpat)
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
385 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
386 char_u *ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
387 char_u *efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
388 int round;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
389 int idx = 0;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
390
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
391 // Build a regexp pattern for a 'errorformat' option part
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
392 ptr = regpat;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
393 *ptr++ = '^';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
394 round = 0;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
395 for (efmp = efm; efmp < efm + len; ++efmp)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
396 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
397 if (*efmp == '%')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
398 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
399 ++efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
400 for (idx = 0; idx < FMT_PATTERNS; ++idx)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
401 if (fmt_pat[idx].convchar == *efmp)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
402 break;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
403 if (idx < FMT_PATTERNS)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
404 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
405 ptr = efmpat_to_regpat(efmp, ptr, fmt_ptr, idx, round);
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
406 if (ptr == NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
407 return FAIL;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
408 round++;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
409 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
410 else if (*efmp == '*')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
411 {
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
412 ++efmp;
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
413 ptr = scanf_fmt_to_regpat(&efmp, efm, len, ptr);
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
414 if (ptr == NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
415 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
416 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
417 else if (vim_strchr((char_u *)"%\\.^$~[", *efmp) != NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
418 *ptr++ = *efmp; // regexp magic characters
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
419 else if (*efmp == '#')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
420 *ptr++ = '*';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
421 else if (*efmp == '>')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
422 fmt_ptr->conthere = TRUE;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
423 else if (efmp == efm + 1) // analyse prefix
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
424 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
425 // prefix is allowed only at the beginning of the errorformat
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
426 // option part
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
427 efmp = efm_analyze_prefix(efmp, fmt_ptr);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
428 if (efmp == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
429 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
430 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
431 else
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
432 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
433 semsg(_("E377: Invalid %%%c in format string"), *efmp);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
434 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
435 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
436 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
437 else // copy normal character
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
438 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
439 if (*efmp == '\\' && efmp + 1 < efm + len)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
440 ++efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
441 else if (vim_strchr((char_u *)".*^$~[", *efmp) != NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
442 *ptr++ = '\\'; // escape regexp atoms
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
443 if (*efmp)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
444 *ptr++ = *efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
445 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
446 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
447 *ptr++ = '$';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
448 *ptr = NUL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
449
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
450 return OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
451 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
452
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
453 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
454 * Free the 'errorformat' information list
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
455 */
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
456 static void
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
457 free_efm_list(efm_T **efm_first)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
458 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
459 efm_T *efm_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
460
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
461 for (efm_ptr = *efm_first; efm_ptr != NULL; efm_ptr = *efm_first)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
462 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
463 *efm_first = efm_ptr->next;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
464 vim_regfree(efm_ptr->prog);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
465 vim_free(efm_ptr);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
466 }
10367
4e4e116e3689 commit https://github.com/vim/vim/commit/63bed3d319b5d90765dbdae93a3579b6322d79fb
Christian Brabandt <cb@256bit.org>
parents: 10359
diff changeset
467 fmt_start = NULL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
468 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
469
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
470 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
471 * Compute the size of the buffer used to convert a 'errorformat' pattern into
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
472 * a regular expression pattern.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
473 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
474 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
475 efm_regpat_bufsz(char_u *efm)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
476 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
477 int sz;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
478 int i;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
479
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
480 sz = (FMT_PATTERNS * 3) + ((int)STRLEN(efm) << 2);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
481 for (i = FMT_PATTERNS; i > 0; )
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
482 sz += (int)STRLEN(fmt_pat[--i].pattern);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
483 #ifdef BACKSLASH_IN_FILENAME
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
484 sz += 12; // "%f" can become twelve chars longer (see efm_to_regpat)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
485 #else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
486 sz += 2; // "%f" can become two chars longer
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
487 #endif
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
488
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
489 return sz;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
490 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
491
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
492 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
493 * Return the length of a 'errorformat' option part (separated by ",").
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
494 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
495 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
496 efm_option_part_len(char_u *efm)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
497 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
498 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
499
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
500 for (len = 0; efm[len] != NUL && efm[len] != ','; ++len)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
501 if (efm[len] == '\\' && efm[len + 1] != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
502 ++len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
503
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
504 return len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
505 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
506
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
507 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
508 * Parse the 'errorformat' option. Multiple parts in the 'errorformat' option
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
509 * are parsed and converted to regular expressions. Returns information about
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
510 * the parsed 'errorformat' option.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
511 */
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
512 static efm_T *
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
513 parse_efm_option(char_u *efm)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
514 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
515 efm_T *fmt_ptr = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
516 efm_T *fmt_first = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
517 efm_T *fmt_last = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
518 char_u *fmtstr = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
519 int len;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
520 int sz;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
521
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
522 // Each part of the format string is copied and modified from errorformat
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
523 // to regex prog. Only a few % characters are allowed.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
524
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
525 // Get some space to modify the format string into.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
526 sz = efm_regpat_bufsz(efm);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
527 if ((fmtstr = alloc(sz)) == NULL)
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
528 goto parse_efm_error;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
529
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
530 while (efm[0] != NUL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
531 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
532 // Allocate a new eformat structure and put it at the end of the list
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
533 fmt_ptr = (efm_T *)alloc_clear((unsigned)sizeof(efm_T));
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
534 if (fmt_ptr == NULL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
535 goto parse_efm_error;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
536 if (fmt_first == NULL) // first one
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
537 fmt_first = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
538 else
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
539 fmt_last->next = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
540 fmt_last = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
541
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
542 // Isolate one part in the 'errorformat' option
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
543 len = efm_option_part_len(efm);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
544
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
545 if (efm_to_regpat(efm, len, fmt_ptr, fmtstr) == FAIL)
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
546 goto parse_efm_error;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
547 if ((fmt_ptr->prog = vim_regcomp(fmtstr, RE_MAGIC + RE_STRING)) == NULL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
548 goto parse_efm_error;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
549 // Advance to next part
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
550 efm = skip_to_option_part(efm + len); // skip comma and spaces
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
551 }
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
552
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
553 if (fmt_first == NULL) // nothing found
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
554 emsg(_("E378: 'errorformat' contains no pattern"));
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
555
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
556 goto parse_efm_end;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
557
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
558 parse_efm_error:
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
559 free_efm_list(&fmt_first);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
560
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
561 parse_efm_end:
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
562 vim_free(fmtstr);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
563
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
564 return fmt_first;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
565 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
566
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
567 enum {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
568 QF_FAIL = 0,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
569 QF_OK = 1,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
570 QF_END_OF_INPUT = 2,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
571 QF_NOMEM = 3,
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
572 QF_IGNORE_LINE = 4,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
573 QF_MULTISCAN = 5,
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
574 };
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
575
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
576 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
577 * State information used to parse lines and add entries to a quickfix/location
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
578 * list.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
579 */
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
580 typedef struct {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
581 char_u *linebuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
582 int linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
583 char_u *growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
584 int growbufsiz;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
585 FILE *fd;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
586 typval_T *tv;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
587 char_u *p_str;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
588 listitem_T *p_li;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
589 buf_T *buf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
590 linenr_T buflnum;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
591 linenr_T lnumlast;
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
592 vimconv_T vc;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
593 } qfstate_T;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
594
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
595 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
596 * Allocate more memory for the line buffer used for parsing lines.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
597 */
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
598 static char_u *
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
599 qf_grow_linebuf(qfstate_T *state, int newsz)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
600 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
601 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
602
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
603 // If the line exceeds LINE_MAXLEN exclude the last
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
604 // byte since it's not a NL character.
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
605 state->linelen = newsz > LINE_MAXLEN ? LINE_MAXLEN - 1 : newsz;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
606 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
607 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
608 state->growbuf = alloc(state->linelen + 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
609 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
610 return NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
611 state->growbufsiz = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
612 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
613 else if (state->linelen > state->growbufsiz)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
614 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
615 if ((p = vim_realloc(state->growbuf, state->linelen + 1)) == NULL)
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
616 return NULL;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
617 state->growbuf = p;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
618 state->growbufsiz = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
619 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
620 return state->growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
621 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
622
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
623 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
624 * Get the next string (separated by newline) from state->p_str.
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
625 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
626 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
627 qf_get_next_str_line(qfstate_T *state)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
628 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
629 // Get the next line from the supplied string
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
630 char_u *p_str = state->p_str;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
631 char_u *p;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
632 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
633
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
634 if (*p_str == NUL) // Reached the end of the string
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
635 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
636
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
637 p = vim_strchr(p_str, '\n');
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
638 if (p != NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
639 len = (int)(p - p_str) + 1;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
640 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
641 len = (int)STRLEN(p_str);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
642
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
643 if (len > IOSIZE - 2)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
644 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
645 state->linebuf = qf_grow_linebuf(state, len);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
646 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
647 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
648 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
649 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
650 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
651 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
652 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
653 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
654 vim_strncpy(state->linebuf, p_str, state->linelen);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
655
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
656 // Increment using len in order to discard the rest of the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
657 // line if it exceeds LINE_MAXLEN.
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
658 p_str += len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
659 state->p_str = p_str;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
660
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
661 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
662 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
663
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
664 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
665 * Get the next string from state->p_Li.
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
666 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
667 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
668 qf_get_next_list_line(qfstate_T *state)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
669 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
670 listitem_T *p_li = state->p_li;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
671 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
672
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
673 while (p_li != NULL
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
674 && (p_li->li_tv.v_type != VAR_STRING
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
675 || p_li->li_tv.vval.v_string == NULL))
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
676 p_li = p_li->li_next; // Skip non-string items
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
677
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
678 if (p_li == NULL) // End of the list
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
679 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
680 state->p_li = NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
681 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
682 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
683
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
684 len = (int)STRLEN(p_li->li_tv.vval.v_string);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
685 if (len > IOSIZE - 2)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
686 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
687 state->linebuf = qf_grow_linebuf(state, len);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
688 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
689 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
690 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
691 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
692 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
693 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
694 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
695 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
696
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
697 vim_strncpy(state->linebuf, p_li->li_tv.vval.v_string, state->linelen);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
698
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
699 state->p_li = p_li->li_next; // next item
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
700 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
701 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
702
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
703 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
704 * Get the next string from state->buf.
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
705 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
706 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
707 qf_get_next_buf_line(qfstate_T *state)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
708 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
709 char_u *p_buf = NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
710 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
711
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
712 // Get the next line from the supplied buffer
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
713 if (state->buflnum > state->lnumlast)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
714 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
715
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
716 p_buf = ml_get_buf(state->buf, state->buflnum, FALSE);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
717 state->buflnum += 1;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
718
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
719 len = (int)STRLEN(p_buf);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
720 if (len > IOSIZE - 2)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
721 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
722 state->linebuf = qf_grow_linebuf(state, len);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
723 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
724 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
725 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
726 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
727 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
728 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
729 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
730 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
731 vim_strncpy(state->linebuf, p_buf, state->linelen);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
732
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
733 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
734 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
735
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
736 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
737 * Get the next string from file state->fd.
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
738 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
739 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
740 qf_get_next_file_line(qfstate_T *state)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
741 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
742 int discard;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
743 int growbuflen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
744
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
745 if (fgets((char *)IObuff, IOSIZE, state->fd) == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
746 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
747
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
748 discard = FALSE;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
749 state->linelen = (int)STRLEN(IObuff);
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
750 if (state->linelen == IOSIZE - 1 && !(IObuff[state->linelen - 1] == '\n'))
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
751 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
752 // The current line exceeds IObuff, continue reading using
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
753 // growbuf until EOL or LINE_MAXLEN bytes is read.
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
754 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
755 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
756 state->growbufsiz = 2 * (IOSIZE - 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
757 state->growbuf = alloc(state->growbufsiz);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
758 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
759 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
760 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
761
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
762 // Copy the read part of the line, excluding null-terminator
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
763 memcpy(state->growbuf, IObuff, IOSIZE - 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
764 growbuflen = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
765
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
766 for (;;)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
767 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
768 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
769
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
770 if (fgets((char *)state->growbuf + growbuflen,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
771 state->growbufsiz - growbuflen, state->fd) == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
772 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
773 state->linelen = (int)STRLEN(state->growbuf + growbuflen);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
774 growbuflen += state->linelen;
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
775 if ((state->growbuf)[growbuflen - 1] == '\n')
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
776 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
777 if (state->growbufsiz == LINE_MAXLEN)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
778 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
779 discard = TRUE;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
780 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
781 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
782
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
783 state->growbufsiz = 2 * state->growbufsiz < LINE_MAXLEN
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
784 ? 2 * state->growbufsiz : LINE_MAXLEN;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
785 if ((p = vim_realloc(state->growbuf, state->growbufsiz)) == NULL)
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
786 return QF_NOMEM;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
787 state->growbuf = p;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
788 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
789
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
790 while (discard)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
791 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
792 // The current line is longer than LINE_MAXLEN, continue
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
793 // reading but discard everything until EOL or EOF is
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
794 // reached.
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
795 if (fgets((char *)IObuff, IOSIZE, state->fd) == NULL
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
796 || (int)STRLEN(IObuff) < IOSIZE - 1
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
797 || IObuff[IOSIZE - 1] == '\n')
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
798 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
799 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
800
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
801 state->linebuf = state->growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
802 state->linelen = growbuflen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
803 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
804 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
805 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
806
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
807 // Convert a line if it contains a non-ASCII character.
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
808 if (state->vc.vc_type != CONV_NONE && has_non_ascii(state->linebuf))
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
809 {
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
810 char_u *line;
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
811
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
812 line = string_convert(&state->vc, state->linebuf, &state->linelen);
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
813 if (line != NULL)
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
814 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
815 if (state->linelen < IOSIZE)
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
816 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
817 STRCPY(state->linebuf, line);
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
818 vim_free(line);
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
819 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
820 else
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
821 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
822 vim_free(state->growbuf);
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
823 state->linebuf = state->growbuf = line;
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
824 state->growbufsiz = state->linelen < LINE_MAXLEN
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
825 ? state->linelen : LINE_MAXLEN;
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
826 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
827 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
828 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
829
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
830 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
831 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
832
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
833 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
834 * Get the next string from a file/buffer/list/string.
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
835 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
836 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
837 qf_get_nextline(qfstate_T *state)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
838 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
839 int status = QF_FAIL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
840
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
841 if (state->fd == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
842 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
843 if (state->tv != NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
844 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
845 if (state->tv->v_type == VAR_STRING)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
846 // Get the next line from the supplied string
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
847 status = qf_get_next_str_line(state);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
848 else if (state->tv->v_type == VAR_LIST)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
849 // Get the next line from the supplied list
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
850 status = qf_get_next_list_line(state);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
851 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
852 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
853 // Get the next line from the supplied buffer
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
854 status = qf_get_next_buf_line(state);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
855 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
856 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
857 // Get the next line from the supplied file
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
858 status = qf_get_next_file_line(state);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
859
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
860 if (status != QF_OK)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
861 return status;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
862
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
863 // remove newline/CR from the line
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
864 if (state->linelen > 0 && state->linebuf[state->linelen - 1] == '\n')
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
865 {
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
866 state->linebuf[state->linelen - 1] = NUL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
867 #ifdef USE_CRNL
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
868 if (state->linelen > 1 && state->linebuf[state->linelen - 2] == '\r')
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
869 state->linebuf[state->linelen - 2] = NUL;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
870 #endif
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
871 }
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
872
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
873 remove_bom(state->linebuf);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
874
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
875 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
876 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
877
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
878 typedef struct {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
879 char_u *namebuf;
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
880 char_u *module;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
881 char_u *errmsg;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
882 int errmsglen;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
883 long lnum;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
884 int col;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
885 char_u use_viscol;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
886 char_u *pattern;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
887 int enr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
888 int type;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
889 int valid;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
890 } qffields_T;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
891
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
892 /*
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
893 * Parse the match for filename ('%f') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
894 * Return the matched value in "fields->namebuf".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
895 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
896 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
897 qf_parse_fmt_f(regmatch_T *rmp, int midx, qffields_T *fields, int prefix)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
898 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
899 int c;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
900
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
901 if (rmp->startp[midx] == NULL || rmp->endp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
902 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
903
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
904 // Expand ~/file and $HOME/file to full path.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
905 c = *rmp->endp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
906 *rmp->endp[midx] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
907 expand_env(rmp->startp[midx], fields->namebuf, CMDBUFFSIZE);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
908 *rmp->endp[midx] = c;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
909
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
910 // For separate filename patterns (%O, %P and %Q), the specified file
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
911 // should exist.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
912 if (vim_strchr((char_u *)"OPQ", prefix) != NULL
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
913 && mch_getperm(fields->namebuf) == -1)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
914 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
915
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
916 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
917 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
918
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
919 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
920 * Parse the match for error number ('%n') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
921 * Return the matched value in "fields->enr".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
922 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
923 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
924 qf_parse_fmt_n(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
925 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
926 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
927 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
928 fields->enr = (int)atol((char *)rmp->startp[midx]);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
929 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
930 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
931
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
932 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
933 * Parse the match for line number (%l') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
934 * Return the matched value in "fields->lnum".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
935 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
936 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
937 qf_parse_fmt_l(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
938 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
939 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
940 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
941 fields->lnum = atol((char *)rmp->startp[midx]);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
942 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
943 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
944
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
945 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
946 * Parse the match for column number ('%c') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
947 * Return the matched value in "fields->col".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
948 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
949 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
950 qf_parse_fmt_c(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
951 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
952 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
953 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
954 fields->col = (int)atol((char *)rmp->startp[midx]);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
955 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
956 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
957
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
958 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
959 * Parse the match for error type ('%t') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
960 * Return the matched value in "fields->type".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
961 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
962 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
963 qf_parse_fmt_t(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
964 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
965 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
966 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
967 fields->type = *rmp->startp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
968 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
969 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
970
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
971 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
972 * Parse the match for '%+' format pattern. The whole matching line is included
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
973 * in the error string. Return the matched line in "fields->errmsg".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
974 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
975 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
976 qf_parse_fmt_plus(char_u *linebuf, int linelen, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
977 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
978 char_u *p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
979
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
980 if (linelen >= fields->errmsglen)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
981 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
982 // linelen + null terminator
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
983 if ((p = vim_realloc(fields->errmsg, linelen + 1)) == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
984 return QF_NOMEM;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
985 fields->errmsg = p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
986 fields->errmsglen = linelen + 1;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
987 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
988 vim_strncpy(fields->errmsg, linebuf, linelen);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
989 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
990 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
991
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
992 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
993 * Parse the match for error message ('%m') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
994 * Return the matched value in "fields->errmsg".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
995 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
996 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
997 qf_parse_fmt_m(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
998 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
999 char_u *p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1000 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1001
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1002 if (rmp->startp[midx] == NULL || rmp->endp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1003 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1004 len = (int)(rmp->endp[midx] - rmp->startp[midx]);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1005 if (len >= fields->errmsglen)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1006 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1007 // len + null terminator
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1008 if ((p = vim_realloc(fields->errmsg, len + 1)) == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1009 return QF_NOMEM;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1010 fields->errmsg = p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1011 fields->errmsglen = len + 1;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1012 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1013 vim_strncpy(fields->errmsg, rmp->startp[midx], len);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1014 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1015 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1016
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1017 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1018 * Parse the match for rest of a single-line file message ('%r') pattern.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1019 * Return the matched value in "tail".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1020 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1021 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1022 qf_parse_fmt_r(regmatch_T *rmp, int midx, char_u **tail)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1023 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1024 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1025 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1026 *tail = rmp->startp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1027 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1028 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1029
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1030 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1031 * Parse the match for the pointer line ('%p') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1032 * Return the matched value in "fields->col".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1033 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1034 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1035 qf_parse_fmt_p(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1036 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1037 char_u *match_ptr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1038
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1039 if (rmp->startp[midx] == NULL || rmp->endp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1040 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1041 fields->col = 0;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1042 for (match_ptr = rmp->startp[midx]; match_ptr != rmp->endp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1043 ++match_ptr)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1044 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1045 ++fields->col;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1046 if (*match_ptr == TAB)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1047 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1048 fields->col += 7;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1049 fields->col -= fields->col % 8;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1050 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1051 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1052 ++fields->col;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1053 fields->use_viscol = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1054 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1055 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1056
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1057 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1058 * Parse the match for the virtual column number ('%v') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1059 * Return the matched value in "fields->col".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1060 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1061 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1062 qf_parse_fmt_v(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1063 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1064 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1065 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1066 fields->col = (int)atol((char *)rmp->startp[midx]);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1067 fields->use_viscol = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1068 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1069 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1070
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1071 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1072 * Parse the match for the search text ('%s') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1073 * Return the matched value in "fields->pattern".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1074 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1075 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1076 qf_parse_fmt_s(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1077 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1078 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1079
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1080 if (rmp->startp[midx] == NULL || rmp->endp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1081 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1082 len = (int)(rmp->endp[midx] - rmp->startp[midx]);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1083 if (len > CMDBUFFSIZE - 5)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1084 len = CMDBUFFSIZE - 5;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1085 STRCPY(fields->pattern, "^\\V");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1086 STRNCAT(fields->pattern, rmp->startp[midx], len);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1087 fields->pattern[len + 3] = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1088 fields->pattern[len + 4] = '$';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1089 fields->pattern[len + 5] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1090 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1091 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1092
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1093 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1094 * Parse the match for the module ('%o') pattern in regmatch.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1095 * Return the matched value in "fields->module".
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1096 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1097 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1098 qf_parse_fmt_o(regmatch_T *rmp, int midx, qffields_T *fields)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1099 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1100 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1101
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1102 if (rmp->startp[midx] == NULL || rmp->endp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1103 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1104 len = (int)(rmp->endp[midx] - rmp->startp[midx]);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1105 if (len > CMDBUFFSIZE)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1106 len = CMDBUFFSIZE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1107 STRNCAT(fields->module, rmp->startp[midx], len);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1108 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1109 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1110
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1111 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1112 * 'errorformat' format pattern parser functions.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1113 * The '%f' and '%r' formats are parsed differently from other formats.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1114 * See qf_parse_match() for details.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1115 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1116 static int (*qf_parse_fmt[FMT_PATTERNS])(regmatch_T *, int, qffields_T *) =
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1117 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1118 NULL,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1119 qf_parse_fmt_n,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1120 qf_parse_fmt_l,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1121 qf_parse_fmt_c,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1122 qf_parse_fmt_t,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1123 qf_parse_fmt_m,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1124 NULL,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1125 qf_parse_fmt_p,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1126 qf_parse_fmt_v,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1127 qf_parse_fmt_s,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1128 qf_parse_fmt_o
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1129 };
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1130
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1131 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1132 * Parse the error format pattern matches in "regmatch" and set the values in
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1133 * "fields". fmt_ptr contains the 'efm' format specifiers/prefixes that have a
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1134 * match. Returns QF_OK if all the matches are successfully parsed. On
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1135 * failure, returns QF_FAIL or QF_NOMEM.
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1136 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1137 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1138 qf_parse_match(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1139 char_u *linebuf,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1140 int linelen,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1141 efm_T *fmt_ptr,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1142 regmatch_T *regmatch,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1143 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1144 int qf_multiline,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1145 int qf_multiscan,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1146 char_u **tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1147 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1148 int idx = fmt_ptr->prefix;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1149 int i;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1150 int midx;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1151 int status;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1152
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1153 if ((idx == 'C' || idx == 'Z') && !qf_multiline)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1154 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1155 if (vim_strchr((char_u *)"EWI", idx) != NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1156 fields->type = idx;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1157 else
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1158 fields->type = 0;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1159
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1160 // Extract error message data from matched line.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1161 // We check for an actual submatch, because "\[" and "\]" in
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1162 // the 'errorformat' may cause the wrong submatch to be used.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1163 for (i = 0; i < FMT_PATTERNS; i++)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1164 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1165 status = QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1166 midx = (int)fmt_ptr->addr[i];
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1167 if (i == 0 && midx > 0) // %f
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1168 status = qf_parse_fmt_f(regmatch, midx, fields, idx);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1169 else if (i == 5)
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1170 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1171 if (fmt_ptr->flags == '+' && !qf_multiscan) // %+
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1172 status = qf_parse_fmt_plus(linebuf, linelen, fields);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1173 else if (midx > 0) // %m
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1174 status = qf_parse_fmt_m(regmatch, midx, fields);
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1175 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1176 else if (i == 6 && midx > 0) // %r
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1177 status = qf_parse_fmt_r(regmatch, midx, tail);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1178 else if (midx > 0) // others
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1179 status = (qf_parse_fmt[i])(regmatch, midx, fields);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1180
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1181 if (status != QF_OK)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1182 return status;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1183 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1184
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1185 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1186 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1187
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1188 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1189 * Parse an error line in 'linebuf' using a single error format string in
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1190 * 'fmt_ptr->prog' and return the matching values in 'fields'.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1191 * Returns QF_OK if the efm format matches completely and the fields are
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1192 * successfully copied. Otherwise returns QF_FAIL or QF_NOMEM.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1193 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1194 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1195 qf_parse_get_fields(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1196 char_u *linebuf,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1197 int linelen,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1198 efm_T *fmt_ptr,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1199 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1200 int qf_multiline,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1201 int qf_multiscan,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1202 char_u **tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1203 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1204 regmatch_T regmatch;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1205 int status = QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1206 int r;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1207
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1208 if (qf_multiscan &&
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1209 vim_strchr((char_u *)"OPQ", fmt_ptr->prefix) == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1210 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1211
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1212 fields->namebuf[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1213 fields->module[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1214 fields->pattern[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1215 if (!qf_multiscan)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1216 fields->errmsg[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1217 fields->lnum = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1218 fields->col = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1219 fields->use_viscol = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1220 fields->enr = -1;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1221 fields->type = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1222 *tail = NULL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1223
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1224 // Always ignore case when looking for a matching error.
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1225 regmatch.rm_ic = TRUE;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1226 regmatch.regprog = fmt_ptr->prog;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1227 r = vim_regexec(&regmatch, linebuf, (colnr_T)0);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1228 fmt_ptr->prog = regmatch.regprog;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1229 if (r)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1230 status = qf_parse_match(linebuf, linelen, fmt_ptr, &regmatch,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1231 fields, qf_multiline, qf_multiscan, tail);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1232
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1233 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1234 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1235
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1236 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1237 * Parse directory error format prefixes (%D and %X).
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1238 * Push and pop directories from the directory stack when scanning directory
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1239 * names.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1240 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1241 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1242 qf_parse_dir_pfx(int idx, qffields_T *fields, qf_list_T *qfl)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1243 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1244 if (idx == 'D') // enter directory
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1245 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1246 if (*fields->namebuf == NUL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1247 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
1248 emsg(_("E379: Missing or empty directory name"));
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1249 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1250 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1251 qfl->qf_directory =
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1252 qf_push_dir(fields->namebuf, &qfl->qf_dir_stack, FALSE);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1253 if (qfl->qf_directory == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1254 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1255 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1256 else if (idx == 'X') // leave directory
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1257 qfl->qf_directory = qf_pop_dir(&qfl->qf_dir_stack);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1258
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1259 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1260 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1261
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1262 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1263 * Parse global file name error format prefixes (%O, %P and %Q).
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1264 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1265 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1266 qf_parse_file_pfx(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1267 int idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1268 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1269 qf_list_T *qfl,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1270 char_u *tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1271 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1272 fields->valid = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1273 if (*fields->namebuf == NUL || mch_getperm(fields->namebuf) >= 0)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1274 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1275 if (*fields->namebuf && idx == 'P')
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1276 qfl->qf_currfile =
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1277 qf_push_dir(fields->namebuf, &qfl->qf_file_stack, TRUE);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1278 else if (idx == 'Q')
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1279 qfl->qf_currfile = qf_pop_dir(&qfl->qf_file_stack);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1280 *fields->namebuf = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1281 if (tail && *tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1282 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1283 STRMOVE(IObuff, skipwhite(tail));
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1284 qfl->qf_multiscan = TRUE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1285 return QF_MULTISCAN;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1286 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1287 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1288
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1289 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1290 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1291
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1292 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1293 * Parse a non-error line (a line which doesn't match any of the error
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1294 * format in 'efm').
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1295 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1296 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1297 qf_parse_line_nomatch(char_u *linebuf, int linelen, qffields_T *fields)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1298 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1299 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1300
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1301 fields->namebuf[0] = NUL; // no match found, remove file name
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1302 fields->lnum = 0; // don't jump to this line
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1303 fields->valid = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1304 if (linelen >= fields->errmsglen)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1305 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1306 // linelen + null terminator
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1307 if ((p = vim_realloc(fields->errmsg, linelen + 1)) == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1308 return QF_NOMEM;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1309 fields->errmsg = p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1310 fields->errmsglen = linelen + 1;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1311 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1312 // copy whole line to error message
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1313 vim_strncpy(fields->errmsg, linebuf, linelen);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1314
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1315 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1316 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1317
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1318 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1319 * Parse multi-line error format prefixes (%C and %Z)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1320 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1321 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1322 qf_parse_multiline_pfx(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1323 qf_info_T *qi,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1324 int qf_idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1325 int idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1326 qf_list_T *qfl,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1327 qffields_T *fields)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1328 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1329 char_u *ptr;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1330 int len;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1331
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1332 if (!qfl->qf_multiignore)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1333 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1334 qfline_T *qfprev = qfl->qf_last;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1335
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1336 if (qfprev == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1337 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1338 if (*fields->errmsg && !qfl->qf_multiignore)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1339 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1340 len = (int)STRLEN(qfprev->qf_text);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1341 if ((ptr = alloc((unsigned)(len + STRLEN(fields->errmsg) + 2)))
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1342 == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1343 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1344 STRCPY(ptr, qfprev->qf_text);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1345 vim_free(qfprev->qf_text);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1346 qfprev->qf_text = ptr;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1347 *(ptr += len) = '\n';
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1348 STRCPY(++ptr, fields->errmsg);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1349 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1350 if (qfprev->qf_nr == -1)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1351 qfprev->qf_nr = fields->enr;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1352 if (vim_isprintc(fields->type) && !qfprev->qf_type)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1353 // only printable chars allowed
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1354 qfprev->qf_type = fields->type;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1355
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1356 if (!qfprev->qf_lnum)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1357 qfprev->qf_lnum = fields->lnum;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1358 if (!qfprev->qf_col)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1359 qfprev->qf_col = fields->col;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1360 qfprev->qf_viscol = fields->use_viscol;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1361 if (!qfprev->qf_fnum)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1362 qfprev->qf_fnum = qf_get_fnum(qi, qf_idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1363 qfl->qf_directory,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1364 *fields->namebuf || qfl->qf_directory != NULL
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1365 ? fields->namebuf
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1366 : qfl->qf_currfile != NULL && fields->valid
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1367 ? qfl->qf_currfile : 0);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1368 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1369 if (idx == 'Z')
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1370 qfl->qf_multiline = qfl->qf_multiignore = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1371 line_breakcheck();
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1372
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1373 return QF_IGNORE_LINE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1374 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1375
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1376 /*
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1377 * Parse a line and get the quickfix fields.
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1378 * Return the QF_ status.
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1379 */
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1380 static int
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1381 qf_parse_line(
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1382 qf_info_T *qi,
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1383 int qf_idx,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1384 char_u *linebuf,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1385 int linelen,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1386 efm_T *fmt_first,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1387 qffields_T *fields)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1388 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1389 efm_T *fmt_ptr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1390 int idx = 0;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1391 char_u *tail = NULL;
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1392 qf_list_T *qfl = &qi->qf_lists[qf_idx];
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1393 int status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1394
13612
89223f5d5d12 patch 8.0.1678: errorformat "%r" implies "%>"
Christian Brabandt <cb@256bit.org>
parents: 13594
diff changeset
1395 restofline:
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1396 // If there was no %> item start at the first pattern
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1397 if (fmt_start == NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1398 fmt_ptr = fmt_first;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1399 else
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1400 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1401 // Otherwise start from the last used pattern
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1402 fmt_ptr = fmt_start;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1403 fmt_start = NULL;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1404 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1405
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1406 // Try to match each part of 'errorformat' until we find a complete
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1407 // match or no match.
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1408 fields->valid = TRUE;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1409 for ( ; fmt_ptr != NULL; fmt_ptr = fmt_ptr->next)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1410 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1411 idx = fmt_ptr->prefix;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1412 status = qf_parse_get_fields(linebuf, linelen, fmt_ptr, fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1413 qfl->qf_multiline, qfl->qf_multiscan, &tail);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1414 if (status == QF_NOMEM)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1415 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1416 if (status == QF_OK)
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1417 break;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1418 }
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1419 qfl->qf_multiscan = FALSE;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1420
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1421 if (fmt_ptr == NULL || idx == 'D' || idx == 'X')
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1422 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1423 if (fmt_ptr != NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1424 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1425 // 'D' and 'X' directory specifiers
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1426 status = qf_parse_dir_pfx(idx, fields, qfl);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1427 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1428 return status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1429 }
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1430
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1431 status = qf_parse_line_nomatch(linebuf, linelen, fields);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1432 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1433 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1434
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1435 if (fmt_ptr == NULL)
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1436 qfl->qf_multiline = qfl->qf_multiignore = FALSE;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1437 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1438 else if (fmt_ptr != NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1439 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1440 // honor %> item
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1441 if (fmt_ptr->conthere)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1442 fmt_start = fmt_ptr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1443
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1444 if (vim_strchr((char_u *)"AEWI", idx) != NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1445 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1446 qfl->qf_multiline = TRUE; // start of a multi-line message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1447 qfl->qf_multiignore = FALSE;// reset continuation
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1448 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1449 else if (vim_strchr((char_u *)"CZ", idx) != NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1450 { // continuation of multi-line msg
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1451 status = qf_parse_multiline_pfx(qi, qf_idx, idx, qfl, fields);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1452 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1453 return status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1454 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1455 else if (vim_strchr((char_u *)"OPQ", idx) != NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1456 { // global file names
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1457 status = qf_parse_file_pfx(idx, fields, qfl, tail);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1458 if (status == QF_MULTISCAN)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1459 goto restofline;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1460 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1461 if (fmt_ptr->flags == '-') // generally exclude this line
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1462 {
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1463 if (qfl->qf_multiline)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1464 // also exclude continuation lines
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1465 qfl->qf_multiignore = TRUE;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1466 return QF_IGNORE_LINE;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1467 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1468 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1469
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1470 return QF_OK;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1471 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1472
9033
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
1473 /*
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1474 * Returns TRUE if the specified quickfix/location stack is empty
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1475 */
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1476 static int
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1477 qf_stack_empty(qf_info_T *qi)
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1478 {
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1479 return qi == NULL || qi->qf_listcount <= 0;
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1480 }
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1481
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1482 /*
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1483 * Returns TRUE if the specified quickfix/location list is empty.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1484 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1485 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1486 qf_list_empty(qf_info_T *qi, int qf_idx)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1487 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1488 if (qi == NULL || qf_idx < 0 || qf_idx >= LISTCOUNT)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1489 return TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1490 return qi->qf_lists[qf_idx].qf_count <= 0;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1491 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1492
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1493 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1494 * Allocate the fields used for parsing lines and populating a quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1495 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1496 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1497 qf_alloc_fields(qffields_T *pfields)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1498 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1499 pfields->namebuf = alloc_id(CMDBUFFSIZE + 1, aid_qf_namebuf);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1500 pfields->module = alloc_id(CMDBUFFSIZE + 1, aid_qf_module);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1501 pfields->errmsglen = CMDBUFFSIZE + 1;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1502 pfields->errmsg = alloc_id(pfields->errmsglen, aid_qf_errmsg);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1503 pfields->pattern = alloc_id(CMDBUFFSIZE + 1, aid_qf_pattern);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1504 if (pfields->namebuf == NULL || pfields->errmsg == NULL
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1505 || pfields->pattern == NULL || pfields->module == NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1506 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1507
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1508 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1509 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1510
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1511 /*
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1512 * Free the fields used for parsing lines and populating a quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1513 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1514 static void
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1515 qf_free_fields(qffields_T *pfields)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1516 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1517 vim_free(pfields->namebuf);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1518 vim_free(pfields->module);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1519 vim_free(pfields->errmsg);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1520 vim_free(pfields->pattern);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1521 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1522
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1523 /*
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1524 * Setup the state information used for parsing lines and populating a
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1525 * quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1526 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1527 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1528 qf_setup_state(
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1529 qfstate_T *pstate,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1530 char_u *enc,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1531 char_u *efile,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1532 typval_T *tv,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1533 buf_T *buf,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1534 linenr_T lnumfirst,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1535 linenr_T lnumlast)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1536 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1537 pstate->vc.vc_type = CONV_NONE;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1538 if (enc != NULL && *enc != NUL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1539 convert_setup(&pstate->vc, enc, p_enc);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1540
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1541 if (efile != NULL && (pstate->fd = mch_fopen((char *)efile, "r")) == NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1542 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
1543 semsg(_(e_openerrf), efile);
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1544 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1545 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1546
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1547 if (tv != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1548 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1549 if (tv->v_type == VAR_STRING)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1550 pstate->p_str = tv->vval.v_string;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1551 else if (tv->v_type == VAR_LIST)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1552 pstate->p_li = tv->vval.v_list->lv_first;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1553 pstate->tv = tv;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1554 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1555 pstate->buf = buf;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1556 pstate->buflnum = lnumfirst;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1557 pstate->lnumlast = lnumlast;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1558
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1559 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1560 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1561
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1562 /*
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1563 * Cleanup the state information used for parsing lines and populating a
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1564 * quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1565 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1566 static void
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1567 qf_cleanup_state(qfstate_T *pstate)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1568 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1569 if (pstate->fd != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1570 fclose(pstate->fd);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1571
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1572 vim_free(pstate->growbuf);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1573 if (pstate->vc.vc_type != CONV_NONE)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1574 convert_setup(&pstate->vc, NULL, NULL);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1575 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1576
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1577 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1578 * Read the errorfile "efile" into memory, line by line, building the error
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1579 * list.
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1580 * Alternative: when "efile" is NULL read errors from buffer "buf".
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1581 * Alternative: when "tv" is not NULL get errors from the string or list.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1582 * Always use 'errorformat' from "buf" if there is a local value.
2411
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
1583 * Then "lnumfirst" and "lnumlast" specify the range of lines to use.
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
1584 * Set the title of the list to "qf_title".
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1585 * Return -1 for error, number of errors for success.
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1586 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1587 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1588 qf_init_ext(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1589 qf_info_T *qi,
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1590 int qf_idx,
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1591 char_u *efile,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1592 buf_T *buf,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1593 typval_T *tv,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1594 char_u *errorformat,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1595 int newlist, // TRUE: start a new error list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1596 linenr_T lnumfirst, // first line number to use
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1597 linenr_T lnumlast, // last line number to use
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1598 char_u *qf_title,
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1599 char_u *enc)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1600 {
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1601 qf_list_T *qfl;
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1602 qfstate_T state;
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1603 qffields_T fields;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1604 qfline_T *old_last = NULL;
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1605 int adding = FALSE;
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1606 static efm_T *fmt_first = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1607 char_u *efm;
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1608 static char_u *last_efm = NULL;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1609 int retval = -1; // default: return error flag
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
1610 int status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1611
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1612 // Do not used the cached buffer, it may have been wiped out.
13244
ac42c4b11dbc patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents: 13115
diff changeset
1613 VIM_CLEAR(qf_last_bufname);
11443
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
1614
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1615 vim_memset(&state, 0, sizeof(state));
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1616 vim_memset(&fields, 0, sizeof(fields));
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1617 if ((qf_alloc_fields(&fields) == FAIL) ||
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1618 (qf_setup_state(&state, enc, efile, tv, buf,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1619 lnumfirst, lnumlast) == FAIL))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1620 goto qf_init_end;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1621
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1622 if (newlist || qf_idx == qi->qf_listcount)
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1623 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1624 // make place for a new list
3965
eccae034465b updated for version 7.3.738
Bram Moolenaar <bram@vim.org>
parents: 3949
diff changeset
1625 qf_new_list(qi, qf_title);
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1626 qf_idx = qi->qf_curlist;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1627 }
11609
6f11697fb92c patch 8.0.0687: minor issues related to quickfix
Christian Brabandt <cb@256bit.org>
parents: 11589
diff changeset
1628 else
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1629 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1630 // Adding to existing list, use last entry.
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1631 adding = TRUE;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1632 if (!qf_list_empty(qi, qf_idx))
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1633 old_last = qi->qf_lists[qf_idx].qf_last;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1634 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1635
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1636 qfl = &qi->qf_lists[qf_idx];
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1637
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1638 // Use the local value of 'errorformat' if it's set.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
1639 if (errorformat == p_efm && tv == NULL && *buf->b_p_efm != NUL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1640 efm = buf->b_p_efm;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1641 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1642 efm = errorformat;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
1643
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1644 // If the errorformat didn't change between calls, then reuse the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1645 // previously parsed values.
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1646 if (last_efm == NULL || (STRCMP(last_efm, efm) != 0))
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1647 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1648 // free the previously parsed data
13244
ac42c4b11dbc patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents: 13115
diff changeset
1649 VIM_CLEAR(last_efm);
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1650 free_efm_list(&fmt_first);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1651
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1652 // parse the current 'efm'
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1653 fmt_first = parse_efm_option(efm);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1654 if (fmt_first != NULL)
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1655 last_efm = vim_strsave(efm);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1656 }
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1657
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1658 if (fmt_first == NULL) // nothing found
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1659 goto error2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1660
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1661 // got_int is reset here, because it was probably set when killing the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1662 // ":make" command, but we still want to read the errorfile then.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1663 got_int = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1664
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1665 // Read the lines in the error file one by one.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1666 // Try to recognize one of the error formats in each line.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1667 while (!got_int)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1668 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1669 // Get the next line from a file/buffer/list/string
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
1670 status = qf_get_nextline(&state);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1671 if (status == QF_NOMEM) // memory alloc failure
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
1672 goto qf_init_end;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1673 if (status == QF_END_OF_INPUT) // end of input
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
1674 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1675
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1676 status = qf_parse_line(qi, qf_idx, state.linebuf, state.linelen,
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1677 fmt_first, &fields);
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1678 if (status == QF_FAIL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1679 goto error2;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1680 if (status == QF_NOMEM)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1681 goto qf_init_end;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1682 if (status == QF_IGNORE_LINE)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1683 continue;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1684
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
1685 if (qf_add_entry(qi,
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1686 qf_idx,
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1687 qfl->qf_directory,
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1688 (*fields.namebuf || qfl->qf_directory != NULL)
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1689 ? fields.namebuf
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1690 : ((qfl->qf_currfile != NULL && fields.valid)
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1691 ? qfl->qf_currfile : (char_u *)NULL),
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
1692 fields.module,
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
1693 0,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1694 fields.errmsg,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1695 fields.lnum,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1696 fields.col,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1697 fields.use_viscol,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1698 fields.pattern,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1699 fields.enr,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1700 fields.type,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1701 fields.valid) == FAIL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1702 goto error2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1703 line_breakcheck();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1704 }
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
1705 if (state.fd == NULL || !ferror(state.fd))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1706 {
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1707 if (qfl->qf_index == 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1708 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1709 // no valid entry found
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1710 qfl->qf_ptr = qfl->qf_start;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1711 qfl->qf_index = 1;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1712 qfl->qf_nonevalid = TRUE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1713 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1714 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1715 {
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1716 qfl->qf_nonevalid = FALSE;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1717 if (qfl->qf_ptr == NULL)
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1718 qfl->qf_ptr = qfl->qf_start;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1719 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1720 // return number of matches
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1721 retval = qfl->qf_count;
9369
ce5b79b005ec commit https://github.com/vim/vim/commit/bcf7772a23624edc0942120e564f6b4ac95604ad
Christian Brabandt <cb@256bit.org>
parents: 9365
diff changeset
1722 goto qf_init_end;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1723 }
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
1724 emsg(_(e_readerrf));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1725 error2:
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1726 if (!adding)
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1727 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1728 // Error when creating a new list. Free the new list
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1729 qf_free(qfl);
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1730 qi->qf_listcount--;
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1731 if (qi->qf_curlist > 0)
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1732 --qi->qf_curlist;
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1733 }
9369
ce5b79b005ec commit https://github.com/vim/vim/commit/bcf7772a23624edc0942120e564f6b4ac95604ad
Christian Brabandt <cb@256bit.org>
parents: 9365
diff changeset
1734 qf_init_end:
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1735 if (qf_idx == qi->qf_curlist)
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1736 qf_update_buffer(qi, old_last);
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1737 qf_cleanup_state(&state);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1738 qf_free_fields(&fields);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1739
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1740 return retval;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1741 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1742
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1743 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1744 * Read the errorfile "efile" into memory, line by line, building the error
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1745 * list. Set the error list's title to qf_title.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1746 * Return -1 for error, number of errors for success.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1747 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1748 int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1749 qf_init(win_T *wp,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1750 char_u *efile,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1751 char_u *errorformat,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1752 int newlist, // TRUE: start a new error list
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1753 char_u *qf_title,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1754 char_u *enc)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1755 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1756 qf_info_T *qi = &ql_info;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1757
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1758 if (wp != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1759 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1760 qi = ll_get_or_alloc_list(wp);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1761 if (qi == NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1762 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1763 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1764
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1765 return qf_init_ext(qi, qi->qf_curlist, efile, curbuf, NULL, errorformat,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1766 newlist, (linenr_T)0, (linenr_T)0, qf_title, enc);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1767 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1768
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1769 /*
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1770 * Set the title of the specified quickfix list. Frees the previous title.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1771 * Prepends ':' to the title.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1772 */
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1773 static void
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1774 qf_store_title(qf_list_T *qfl, char_u *title)
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1775 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1776 VIM_CLEAR(qfl->qf_title);
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
1777
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1778 if (title != NULL)
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1779 {
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1780 char_u *p = alloc((int)STRLEN(title) + 2);
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1781
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1782 qfl->qf_title = p;
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1783 if (p != NULL)
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1784 STRCPY(p, title);
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1785 }
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1786 }
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1787
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1788 /*
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1789 * The title of a quickfix/location list is set, by default, to the command
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1790 * that created the quickfix list with the ":" prefix.
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1791 * Create a quickfix list title string by prepending ":" to a user command.
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1792 * Returns a pointer to a static buffer with the title.
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1793 */
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1794 static char_u *
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1795 qf_cmdtitle(char_u *cmd)
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1796 {
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1797 static char_u qftitle_str[IOSIZE];
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1798
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1799 vim_snprintf((char *)qftitle_str, IOSIZE, ":%s", (char *)cmd);
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1800 return qftitle_str;
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1801 }
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1802
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1803 /*
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
1804 * Prepare for adding a new quickfix list. If the current list is in the
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
1805 * middle of the stack, then all the following lists are freed and then
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
1806 * the new list is added.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1807 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1808 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1809 qf_new_list(qf_info_T *qi, char_u *qf_title)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1810 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1811 int i;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1812 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1813
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1814 // If the current entry is not the last entry, delete entries beyond
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1815 // the current entry. This makes it possible to browse in a tree-like
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1816 // way with ":grep'.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1817 while (qi->qf_listcount > qi->qf_curlist + 1)
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1818 qf_free(&qi->qf_lists[--qi->qf_listcount]);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1819
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1820 // When the stack is full, remove to oldest entry
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1821 // Otherwise, add a new entry.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1822 if (qi->qf_listcount == LISTCOUNT)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1823 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1824 qf_free(&qi->qf_lists[0]);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1825 for (i = 1; i < LISTCOUNT; ++i)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1826 qi->qf_lists[i - 1] = qi->qf_lists[i];
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1827 qi->qf_curlist = LISTCOUNT - 1;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1828 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1829 else
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1830 qi->qf_curlist = qi->qf_listcount++;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1831 qfl = &qi->qf_lists[qi->qf_curlist];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1832 vim_memset(qfl, 0, (size_t)(sizeof(qf_list_T)));
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1833 qf_store_title(qfl, qf_title);
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
1834 qfl->qfl_type = qi->qfl_type;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1835 qfl->qf_id = ++last_qf_id;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1836 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1837
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1838 /*
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1839 * Queue location list stack delete request.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1840 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1841 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1842 locstack_queue_delreq(qf_info_T *qi)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1843 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1844 qf_delq_T *q;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1845
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1846 q = (qf_delq_T *)alloc((unsigned)sizeof(qf_delq_T));
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1847 if (q != NULL)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1848 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1849 q->qi = qi;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1850 q->next = qf_delq_head;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1851 qf_delq_head = q;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1852 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1853 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1854
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1855 /*
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1856 * Free a location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1857 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1858 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1859 ll_free_all(qf_info_T **pqi)
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1860 {
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1861 int i;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1862 qf_info_T *qi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1863
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1864 qi = *pqi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1865 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1866 return;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1867 *pqi = NULL; // Remove reference to this list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1868
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1869 qi->qf_refcount--;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1870 if (qi->qf_refcount < 1)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1871 {
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1872 // No references to this location list.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1873 // If the location list is still in use, then queue the delete request
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1874 // to be processed later.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1875 if (quickfix_busy > 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1876 locstack_queue_delreq(qi);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1877 else
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1878 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1879 for (i = 0; i < qi->qf_listcount; ++i)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1880 qf_free(&qi->qf_lists[i]);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1881 vim_free(qi);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1882 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1883 }
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1884 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1885
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1886 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1887 * Free all the quickfix/location lists in the stack.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1888 */
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1889 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1890 qf_free_all(win_T *wp)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1891 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1892 int i;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1893 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1894
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1895 if (wp != NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1896 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1897 // location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1898 ll_free_all(&wp->w_llist);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1899 ll_free_all(&wp->w_llist_ref);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1900 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1901 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1902 // quickfix list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1903 for (i = 0; i < qi->qf_listcount; ++i)
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1904 qf_free(&qi->qf_lists[i]);
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1905 }
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1906
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1907 /*
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1908 * Delay freeing of location list stacks when the quickfix code is running.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1909 * Used to avoid problems with autocmds freeing location list stacks when the
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1910 * quickfix code is still referencing the stack.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1911 * Must always call decr_quickfix_busy() exactly once after this.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1912 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1913 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1914 incr_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1915 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1916 quickfix_busy++;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1917 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1918
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1919 /*
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1920 * Safe to free location list stacks. Process any delayed delete requests.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1921 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1922 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1923 decr_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1924 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1925 if (--quickfix_busy == 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1926 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1927 // No longer referencing the location lists. Process all the pending
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1928 // delete requests.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1929 while (qf_delq_head != NULL)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1930 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1931 qf_delq_T *q = qf_delq_head;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1932
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1933 qf_delq_head = q->next;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1934 ll_free_all(&q->qi);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1935 vim_free(q);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1936 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1937 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1938 #ifdef ABORT_ON_INTERNAL_ERROR
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1939 if (quickfix_busy < 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1940 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
1941 emsg("quickfix_busy has become negative");
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1942 abort();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1943 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1944 #endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1945 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1946
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1947 #if defined(EXITFREE) || defined(PROTO)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1948 void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1949 check_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1950 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1951 if (quickfix_busy != 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1952 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
1953 semsg("quickfix_busy not zero on exit: %ld", (long)quickfix_busy);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1954 # ifdef ABORT_ON_INTERNAL_ERROR
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1955 abort();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1956 # endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1957 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1958 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1959 #endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1960
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1961 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1962 * Add an entry to the end of the list of errors.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1963 * Returns OK or FAIL.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1964 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1965 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1966 qf_add_entry(
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1967 qf_info_T *qi, // quickfix list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1968 int qf_idx, // list index
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1969 char_u *dir, // optional directory name
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1970 char_u *fname, // file name or NULL
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1971 char_u *module, // module name or NULL
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1972 int bufnum, // buffer number or zero
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1973 char_u *mesg, // message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1974 long lnum, // line number
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1975 int col, // column
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1976 int vis_col, // using visual column
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1977 char_u *pattern, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1978 int nr, // error number
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1979 int type, // type character
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1980 int valid) // valid entry
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1981 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1982 qf_list_T *qfl = &qi->qf_lists[qf_idx];
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
1983 qfline_T *qfp;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1984 qfline_T **lastp; // pointer to qf_last or NULL
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1985
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
1986 if ((qfp = (qfline_T *)alloc((unsigned)sizeof(qfline_T))) == NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1987 return FAIL;
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
1988 if (bufnum != 0)
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
1989 {
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
1990 buf_T *buf = buflist_findnr(bufnum);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
1991
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
1992 qfp->qf_fnum = bufnum;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
1993 if (buf != NULL)
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
1994 buf->b_has_qf_entry |=
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
1995 IS_QF_LIST(qfl) ? BUF_HAS_QF_ENTRY : BUF_HAS_LL_ENTRY;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
1996 }
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
1997 else
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
1998 qfp->qf_fnum = qf_get_fnum(qi, qf_idx, dir, fname);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1999 if ((qfp->qf_text = vim_strsave(mesg)) == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2000 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2001 vim_free(qfp);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2002 return FAIL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2003 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2004 qfp->qf_lnum = lnum;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2005 qfp->qf_col = col;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
2006 qfp->qf_viscol = vis_col;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2007 if (pattern == NULL || *pattern == NUL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2008 qfp->qf_pattern = NULL;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2009 else if ((qfp->qf_pattern = vim_strsave(pattern)) == NULL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2010 {
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2011 vim_free(qfp->qf_text);
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2012 vim_free(qfp);
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2013 return FAIL;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2014 }
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2015 if (module == NULL || *module == NUL)
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2016 qfp->qf_module = NULL;
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2017 else if ((qfp->qf_module = vim_strsave(module)) == NULL)
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2018 {
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2019 vim_free(qfp->qf_text);
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2020 vim_free(qfp->qf_pattern);
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2021 vim_free(qfp);
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2022 return FAIL;
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2023 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2024 qfp->qf_nr = nr;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2025 if (type != 1 && !vim_isprintc(type)) // only printable chars allowed
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2026 type = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2027 qfp->qf_type = type;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2028 qfp->qf_valid = valid;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2029
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2030 lastp = &qfl->qf_last;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2031 if (qf_list_empty(qi, qf_idx)) // first element in the list
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2032 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2033 qfl->qf_start = qfp;
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2034 qfl->qf_ptr = qfp;
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2035 qfl->qf_index = 0;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2036 qfp->qf_prev = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2037 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2038 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2039 {
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2040 qfp->qf_prev = *lastp;
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2041 (*lastp)->qf_next = qfp;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2042 }
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2043 qfp->qf_next = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2044 qfp->qf_cleared = FALSE;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2045 *lastp = qfp;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2046 ++qfl->qf_count;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2047 if (qfl->qf_index == 0 && qfp->qf_valid) // first valid entry
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2048 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2049 qfl->qf_index = qfl->qf_count;
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2050 qfl->qf_ptr = qfp;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2051 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2052
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2053 return OK;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2054 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2055
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2056 /*
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2057 * Allocate a new quickfix/location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2058 */
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2059 static qf_info_T *
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2060 qf_alloc_stack(qfltype_T qfltype)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2061 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2062 qf_info_T *qi;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2063
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
2064 qi = (qf_info_T *)alloc_clear((unsigned)sizeof(qf_info_T));
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2065 if (qi != NULL)
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2066 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2067 qi->qf_refcount++;
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2068 qi->qfl_type = qfltype;
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2069 }
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2070 return qi;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2071 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2072
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2073 /*
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2074 * Return the location list stack for window 'wp'.
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2075 * If not present, allocate a location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2076 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2077 static qf_info_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2078 ll_get_or_alloc_list(win_T *wp)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2079 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2080 if (IS_LL_WINDOW(wp))
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2081 // For a location list window, use the referenced location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2082 return wp->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2083
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2084 // For a non-location list window, w_llist_ref should not point to a
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2085 // location list.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2086 ll_free_all(&wp->w_llist_ref);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2087
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2088 if (wp->w_llist == NULL)
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2089 wp->w_llist = qf_alloc_stack(QFLT_LOCATION); // new location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2090 return wp->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2091 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2092
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2093 /*
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2094 * Copy location list entries from 'from_qfl' to 'to_qfl'.
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2095 */
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2096 static int
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2097 copy_loclist_entries(qf_list_T *from_qfl, qf_list_T *to_qfl, qf_info_T *to_qi)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2098 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2099 int i;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2100 qfline_T *from_qfp;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2101 qfline_T *prevp;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2102
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2103 // copy all the location entries in this list
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2104 for (i = 0, from_qfp = from_qfl->qf_start;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2105 i < from_qfl->qf_count && from_qfp != NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2106 ++i, from_qfp = from_qfp->qf_next)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2107 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2108 if (qf_add_entry(to_qi,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2109 to_qi->qf_curlist,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2110 NULL,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2111 NULL,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2112 from_qfp->qf_module,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2113 0,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2114 from_qfp->qf_text,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2115 from_qfp->qf_lnum,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2116 from_qfp->qf_col,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2117 from_qfp->qf_viscol,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2118 from_qfp->qf_pattern,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2119 from_qfp->qf_nr,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2120 0,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2121 from_qfp->qf_valid) == FAIL)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2122 return FAIL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2123
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2124 // qf_add_entry() will not set the qf_num field, as the
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2125 // directory and file names are not supplied. So the qf_fnum
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2126 // field is copied here.
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2127 prevp = to_qfl->qf_last;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2128 prevp->qf_fnum = from_qfp->qf_fnum; // file number
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2129 prevp->qf_type = from_qfp->qf_type; // error type
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2130 if (from_qfl->qf_ptr == from_qfp)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2131 to_qfl->qf_ptr = prevp; // current location
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2132 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2133
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2134 return OK;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2135 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2136
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2137 /*
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2138 * Copy the specified location list 'from_qfl' to 'to_qfl'.
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2139 */
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2140 static int
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2141 copy_loclist(qf_list_T *from_qfl, qf_list_T *to_qfl, qf_info_T *to_qi)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2142 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2143 // Some of the fields are populated by qf_add_entry()
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2144 to_qfl->qfl_type = from_qfl->qfl_type;
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2145 to_qfl->qf_nonevalid = from_qfl->qf_nonevalid;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2146 to_qfl->qf_count = 0;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2147 to_qfl->qf_index = 0;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2148 to_qfl->qf_start = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2149 to_qfl->qf_last = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2150 to_qfl->qf_ptr = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2151 if (from_qfl->qf_title != NULL)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2152 to_qfl->qf_title = vim_strsave(from_qfl->qf_title);
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2153 else
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2154 to_qfl->qf_title = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2155 if (from_qfl->qf_ctx != NULL)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2156 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2157 to_qfl->qf_ctx = alloc_tv();
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2158 if (to_qfl->qf_ctx != NULL)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2159 copy_tv(from_qfl->qf_ctx, to_qfl->qf_ctx);
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2160 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2161 else
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2162 to_qfl->qf_ctx = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2163
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2164 if (from_qfl->qf_count)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2165 if (copy_loclist_entries(from_qfl, to_qfl, to_qi) == FAIL)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2166 return FAIL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2167
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2168 to_qfl->qf_index = from_qfl->qf_index; // current index in the list
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2169
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2170 // Assign a new ID for the location list
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2171 to_qfl->qf_id = ++last_qf_id;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2172 to_qfl->qf_changedtick = 0L;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2173
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2174 // When no valid entries are present in the list, qf_ptr points to
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2175 // the first item in the list
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2176 if (to_qfl->qf_nonevalid)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2177 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2178 to_qfl->qf_ptr = to_qfl->qf_start;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2179 to_qfl->qf_index = 1;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2180 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2181
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2182 return OK;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2183 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2184
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2185 /*
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2186 * Copy the location list stack 'from' window to 'to' window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2187 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2188 void
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2189 copy_loclist_stack(win_T *from, win_T *to)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2190 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2191 qf_info_T *qi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2192 int idx;
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2193
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2194 // When copying from a location list window, copy the referenced
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2195 // location list. For other windows, copy the location list for
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2196 // that window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2197 if (IS_LL_WINDOW(from))
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2198 qi = from->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2199 else
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2200 qi = from->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2201
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2202 if (qi == NULL) // no location list to copy
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2203 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2204
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2205 // allocate a new location list
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2206 if ((to->w_llist = qf_alloc_stack(QFLT_LOCATION)) == NULL)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2207 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2208
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2209 to->w_llist->qf_listcount = qi->qf_listcount;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2210
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2211 // Copy the location lists one at a time
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
2212 for (idx = 0; idx < qi->qf_listcount; ++idx)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2213 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2214 to->w_llist->qf_curlist = idx;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2215
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2216 if (copy_loclist(&qi->qf_lists[idx],
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2217 &to->w_llist->qf_lists[idx], to->w_llist) == FAIL)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2218 {
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2219 qf_free_all(to);
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2220 return;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2221 }
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2222 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2223
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2224 to->w_llist->qf_curlist = qi->qf_curlist; // current list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2225 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2226
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2227 /*
10379
73e2a7abe2a3 commit https://github.com/vim/vim/commit/7618e00d3b8bfe064cfc524640d754607361f9df
Christian Brabandt <cb@256bit.org>
parents: 10369
diff changeset
2228 * Get buffer number for file "directory/fname".
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2229 * Also sets the b_has_qf_entry flag.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2230 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2231 static int
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
2232 qf_get_fnum(qf_info_T *qi, int qf_idx, char_u *directory, char_u *fname)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2233 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
2234 qf_list_T *qfl = &qi->qf_lists[qf_idx];
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2235 char_u *ptr = NULL;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2236 buf_T *buf;
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2237 char_u *bufname;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2238
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2239 if (fname == NULL || *fname == NUL) // no file name
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2240 return 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2241
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2242 #ifdef VMS
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2243 vms_remove_version(fname);
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2244 #endif
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2245 #ifdef BACKSLASH_IN_FILENAME
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2246 if (directory != NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2247 slash_adjust(directory);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2248 slash_adjust(fname);
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2249 #endif
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2250 if (directory != NULL && !vim_isAbsName(fname)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2251 && (ptr = concat_fnames(directory, fname, TRUE)) != NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2252 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2253 // Here we check if the file really exists.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2254 // This should normally be true, but if make works without
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2255 // "leaving directory"-messages we might have missed a
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2256 // directory change.
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2257 if (mch_getperm(ptr) < 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2258 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2259 vim_free(ptr);
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
2260 directory = qf_guess_filepath(qfl, fname);
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2261 if (directory)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2262 ptr = concat_fnames(directory, fname, TRUE);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2263 else
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2264 ptr = vim_strsave(fname);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2265 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2266 // Use concatenated directory name and file name
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2267 bufname = ptr;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2268 }
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2269 else
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2270 bufname = fname;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2271
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2272 if (qf_last_bufname != NULL && STRCMP(bufname, qf_last_bufname) == 0
9475
4d8f7f8da90c commit https://github.com/vim/vim/commit/b25f9a97e9aad3cbb4bc3fe87cdbd5700f8aa0c6
Christian Brabandt <cb@256bit.org>
parents: 9473
diff changeset
2273 && bufref_valid(&qf_last_bufref))
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2274 {
9475
4d8f7f8da90c commit https://github.com/vim/vim/commit/b25f9a97e9aad3cbb4bc3fe87cdbd5700f8aa0c6
Christian Brabandt <cb@256bit.org>
parents: 9473
diff changeset
2275 buf = qf_last_bufref.br_buf;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2276 vim_free(ptr);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2277 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2278 else
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2279 {
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2280 vim_free(qf_last_bufname);
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2281 buf = buflist_new(bufname, NULL, (linenr_T)0, BLN_NOOPT);
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2282 if (bufname == ptr)
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2283 qf_last_bufname = bufname;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2284 else
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2285 qf_last_bufname = vim_strsave(bufname);
9475
4d8f7f8da90c commit https://github.com/vim/vim/commit/b25f9a97e9aad3cbb4bc3fe87cdbd5700f8aa0c6
Christian Brabandt <cb@256bit.org>
parents: 9473
diff changeset
2286 set_bufref(&qf_last_bufref, buf);
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2287 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2288 if (buf == NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2289 return 0;
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2290
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
2291 buf->b_has_qf_entry =
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2292 IS_QF_LIST(qfl) ? BUF_HAS_QF_ENTRY : BUF_HAS_LL_ENTRY;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2293 return buf->b_fnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2294 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2295
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2296 /*
9334
674f9e3ccd1a commit https://github.com/vim/vim/commit/38df43bd13a2498cc96b3ddd9a20dd75126bd171
Christian Brabandt <cb@256bit.org>
parents: 9201
diff changeset
2297 * Push dirbuf onto the directory stack and return pointer to actual dir or
674f9e3ccd1a commit https://github.com/vim/vim/commit/38df43bd13a2498cc96b3ddd9a20dd75126bd171
Christian Brabandt <cb@256bit.org>
parents: 9201
diff changeset
2298 * NULL on error.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2299 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2300 static char_u *
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
2301 qf_push_dir(char_u *dirbuf, struct dir_stack_T **stackptr, int is_file_stack)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2302 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2303 struct dir_stack_T *ds_new;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2304 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2305
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2306 // allocate new stack element and hook it in
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2307 ds_new = (struct dir_stack_T *)alloc((unsigned)sizeof(struct dir_stack_T));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2308 if (ds_new == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2309 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2310
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2311 ds_new->next = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2312 *stackptr = ds_new;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2313
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2314 // store directory on the stack
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2315 if (vim_isAbsName(dirbuf)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2316 || (*stackptr)->next == NULL
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
2317 || (*stackptr && is_file_stack))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2318 (*stackptr)->dirname = vim_strsave(dirbuf);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2319 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2320 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2321 // Okay we don't have an absolute path.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2322 // dirbuf must be a subdir of one of the directories on the stack.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2323 // Let's search...
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2324 ds_new = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2325 (*stackptr)->dirname = NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2326 while (ds_new)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2327 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2328 vim_free((*stackptr)->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2329 (*stackptr)->dirname = concat_fnames(ds_new->dirname, dirbuf,
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2330 TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2331 if (mch_isdir((*stackptr)->dirname) == TRUE)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2332 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2333
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2334 ds_new = ds_new->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2335 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2336
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2337 // clean up all dirs we already left
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2338 while ((*stackptr)->next != ds_new)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2339 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2340 ds_ptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2341 (*stackptr)->next = (*stackptr)->next->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2342 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2343 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2344 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2345
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2346 // Nothing found -> it must be on top level
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2347 if (ds_new == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2348 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2349 vim_free((*stackptr)->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2350 (*stackptr)->dirname = vim_strsave(dirbuf);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2351 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2352 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2353
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2354 if ((*stackptr)->dirname != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2355 return (*stackptr)->dirname;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2356 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2357 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2358 ds_ptr = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2359 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2360 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2361 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2362 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2363 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2364
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2365 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2366 * pop dirbuf from the directory stack and return previous directory or NULL if
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2367 * stack is empty
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2368 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2369 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2370 qf_pop_dir(struct dir_stack_T **stackptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2371 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2372 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2373
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2374 // TODO: Should we check if dirbuf is the directory on top of the stack?
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2375 // What to do if it isn't?
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2376
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2377 // pop top element and free it
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2378 if (*stackptr != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2379 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2380 ds_ptr = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2381 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2382 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2383 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2384 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2385
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2386 // return NEW top element as current dir or NULL if stack is empty
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2387 return *stackptr ? (*stackptr)->dirname : NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2388 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2389
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2390 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2391 * clean up directory stack
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2392 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2393 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2394 qf_clean_dir_stack(struct dir_stack_T **stackptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2395 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2396 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2397
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2398 while ((ds_ptr = *stackptr) != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2399 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2400 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2401 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2402 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2403 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2404 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2405
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2406 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2407 * Check in which directory of the directory stack the given file can be
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2408 * found.
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
2409 * Returns a pointer to the directory name or NULL if not found.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2410 * Cleans up intermediate directory entries.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2411 *
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2412 * TODO: How to solve the following problem?
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2413 * If we have this directory tree:
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2414 * ./
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2415 * ./aa
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2416 * ./aa/bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2417 * ./bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2418 * ./bb/x.c
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2419 * and make says:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2420 * making all in aa
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2421 * making all in bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2422 * x.c:9: Error
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2423 * Then qf_push_dir thinks we are in ./aa/bb, but we are in ./bb.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2424 * qf_guess_filepath will return NULL.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2425 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2426 static char_u *
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2427 qf_guess_filepath(qf_list_T *qfl, char_u *filename)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2428 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2429 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2430 struct dir_stack_T *ds_tmp;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2431 char_u *fullname;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2432
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2433 // no dirs on the stack - there's nothing we can do
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
2434 if (qfl->qf_dir_stack == NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2435 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2436
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
2437 ds_ptr = qfl->qf_dir_stack->next;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2438 fullname = NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2439 while (ds_ptr)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2440 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2441 vim_free(fullname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2442 fullname = concat_fnames(ds_ptr->dirname, filename, TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2443
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2444 // If concat_fnames failed, just go on. The worst thing that can happen
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2445 // is that we delete the entire stack.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2446 if ((fullname != NULL) && (mch_getperm(fullname) >= 0))
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2447 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2448
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2449 ds_ptr = ds_ptr->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2450 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2451
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2452 vim_free(fullname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2453
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2454 // clean up all dirs we already left
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
2455 while (qfl->qf_dir_stack->next != ds_ptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2456 {
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
2457 ds_tmp = qfl->qf_dir_stack->next;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
2458 qfl->qf_dir_stack->next = qfl->qf_dir_stack->next->next;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2459 vim_free(ds_tmp->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2460 vim_free(ds_tmp);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2461 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2462
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2463 return ds_ptr == NULL ? NULL : ds_ptr->dirname;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2464 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2465
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2466 /*
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2467 * Returns TRUE if a quickfix/location list with the given identifier exists.
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2468 */
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2469 static int
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
2470 qflist_valid(win_T *wp, int_u qf_id)
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2471 {
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2472 qf_info_T *qi = &ql_info;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2473 int i;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2474
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2475 if (wp != NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2476 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2477 qi = GET_LOC_LIST(wp); // Location list
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2478 if (qi == NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2479 return FALSE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2480 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2481
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2482 for (i = 0; i < qi->qf_listcount; ++i)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2483 if (qi->qf_lists[i].qf_id == qf_id)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2484 return TRUE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2485
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2486 return FALSE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2487 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2488
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2489 /*
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
2490 * When loading a file from the quickfix, the autocommands may modify it.
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2491 * This may invalidate the current quickfix entry. This function checks
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2492 * whether an entry is still present in the quickfix list.
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2493 * Similar to location list.
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2494 */
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2495 static int
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2496 is_qf_entry_present(qf_list_T *qfl, qfline_T *qf_ptr)
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2497 {
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2498 qfline_T *qfp;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2499 int i;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2500
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2501 // Search for the entry in the current list
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2502 for (i = 0, qfp = qfl->qf_start; i < qfl->qf_count;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2503 ++i, qfp = qfp->qf_next)
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2504 if (qfp == NULL || qfp == qf_ptr)
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2505 break;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2506
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2507 if (i == qfl->qf_count) // Entry is not found
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2508 return FALSE;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2509
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2510 return TRUE;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2511 }
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2512
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2513 /*
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2514 * Get the next valid entry in the current quickfix/location list. The search
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2515 * starts from the current entry. Returns NULL on failure.
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2516 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2517 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2518 get_next_valid_entry(
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2519 qf_list_T *qfl,
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2520 qfline_T *qf_ptr,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2521 int *qf_index,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2522 int dir)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2523 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2524 int idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2525 int old_qf_fnum;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2526
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2527 idx = *qf_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2528 old_qf_fnum = qf_ptr->qf_fnum;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2529
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2530 do
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2531 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2532 if (idx == qfl->qf_count || qf_ptr->qf_next == NULL)
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2533 return NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2534 ++idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2535 qf_ptr = qf_ptr->qf_next;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2536 } while ((!qfl->qf_nonevalid && !qf_ptr->qf_valid)
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2537 || (dir == FORWARD_FILE && qf_ptr->qf_fnum == old_qf_fnum));
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2538
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2539 *qf_index = idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2540 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2541 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2542
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2543 /*
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2544 * Get the previous valid entry in the current quickfix/location list. The
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2545 * search starts from the current entry. Returns NULL on failure.
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2546 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2547 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2548 get_prev_valid_entry(
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2549 qf_list_T *qfl,
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2550 qfline_T *qf_ptr,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2551 int *qf_index,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2552 int dir)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2553 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2554 int idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2555 int old_qf_fnum;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2556
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2557 idx = *qf_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2558 old_qf_fnum = qf_ptr->qf_fnum;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2559
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2560 do
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2561 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2562 if (idx == 1 || qf_ptr->qf_prev == NULL)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2563 return NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2564 --idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2565 qf_ptr = qf_ptr->qf_prev;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2566 } while ((!qfl->qf_nonevalid && !qf_ptr->qf_valid)
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2567 || (dir == BACKWARD_FILE && qf_ptr->qf_fnum == old_qf_fnum));
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2568
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2569 *qf_index = idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2570 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2571 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2572
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2573 /*
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2574 * Get the n'th (errornr) previous/next valid entry from the current entry in
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2575 * the quickfix list.
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2576 * dir == FORWARD or FORWARD_FILE: next valid entry
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2577 * dir == BACKWARD or BACKWARD_FILE: previous valid entry
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2578 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2579 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2580 get_nth_valid_entry(
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2581 qf_list_T *qfl,
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2582 int errornr,
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2583 int dir,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2584 int *new_qfidx)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2585 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2586 qfline_T *qf_ptr = qfl->qf_ptr;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2587 int qf_idx = qfl->qf_index;
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2588 qfline_T *prev_qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2589 int prev_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2590 static char_u *e_no_more_items = (char_u *)N_("E553: No more items");
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2591 char_u *err = e_no_more_items;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2592
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2593 while (errornr--)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2594 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2595 prev_qf_ptr = qf_ptr;
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2596 prev_index = qf_idx;
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2597
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2598 if (dir == FORWARD || dir == FORWARD_FILE)
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2599 qf_ptr = get_next_valid_entry(qfl, qf_ptr, &qf_idx, dir);
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2600 else
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2601 qf_ptr = get_prev_valid_entry(qfl, qf_ptr, &qf_idx, dir);
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2602 if (qf_ptr == NULL)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2603 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2604 qf_ptr = prev_qf_ptr;
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2605 qf_idx = prev_index;
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2606 if (err != NULL)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2607 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
2608 emsg(_(err));
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2609 return NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2610 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2611 break;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2612 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2613
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2614 err = NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2615 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2616
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2617 *new_qfidx = qf_idx;
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2618 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2619 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2620
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2621 /*
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2622 * Get n'th (errornr) quickfix entry from the current entry in the quickfix
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2623 * list 'qfl'. Returns a pointer to the new entry and the index in 'new_qfidx'
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2624 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2625 static qfline_T *
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2626 get_nth_entry(qf_list_T *qfl, int errornr, int *new_qfidx)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2627 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2628 qfline_T *qf_ptr = qfl->qf_ptr;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2629 int qf_idx = qfl->qf_index;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2630
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2631 // New error number is less than the current error number
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2632 while (errornr < qf_idx && qf_idx > 1 && qf_ptr->qf_prev != NULL)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2633 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2634 --qf_idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2635 qf_ptr = qf_ptr->qf_prev;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2636 }
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2637 // New error number is greater than the current error number
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2638 while (errornr > qf_idx && qf_idx < qfl->qf_count &&
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2639 qf_ptr->qf_next != NULL)
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2640 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2641 ++qf_idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2642 qf_ptr = qf_ptr->qf_next;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2643 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2644
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2645 *new_qfidx = qf_idx;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2646 return qf_ptr;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2647 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2648
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2649 /*
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2650 * Get a entry specied by 'errornr' and 'dir' from the current
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2651 * quickfix/location list. 'errornr' specifies the index of the entry and 'dir'
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2652 * specifies the direction (FORWARD/BACKWARD/FORWARD_FILE/BACKWARD_FILE).
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2653 * Returns a pointer to the entry and the index of the new entry is stored in
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2654 * 'new_qfidx'.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2655 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2656 static qfline_T *
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2657 qf_get_entry(
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2658 qf_list_T *qfl,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2659 int errornr,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2660 int dir,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2661 int *new_qfidx)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2662 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2663 qfline_T *qf_ptr = qfl->qf_ptr;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2664 int qfidx = qfl->qf_index;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2665
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2666 if (dir != 0) // next/prev valid entry
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2667 qf_ptr = get_nth_valid_entry(qfl, errornr, dir, &qfidx);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2668 else if (errornr != 0) // go to specified number
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2669 qf_ptr = get_nth_entry(qfl, errornr, &qfidx);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2670
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2671 *new_qfidx = qfidx;
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2672 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2673 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2674
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2675 /*
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2676 * Find a window displaying a Vim help file.
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2677 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2678 static win_T *
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2679 qf_find_help_win(void)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2680 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2681 win_T *wp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2682
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2683 FOR_ALL_WINDOWS(wp)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2684 if (bt_help(wp->w_buffer))
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2685 return wp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2686
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2687 return NULL;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2688 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2689
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2690 /*
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2691 * Find a help window or open one. If 'newwin' is TRUE, then open a new help
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2692 * window.
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2693 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2694 static int
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2695 jump_to_help_window(qf_info_T *qi, int newwin, int *opened_window)
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2696 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2697 win_T *wp;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2698 int flags;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2699
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2700 if (cmdmod.tab != 0 || newwin)
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2701 wp = NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2702 else
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2703 wp = qf_find_help_win();
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2704 if (wp != NULL && wp->w_buffer->b_nwindows > 0)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2705 win_enter(wp, TRUE);
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2706 else
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2707 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2708 // Split off help window; put it at far top if no position
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2709 // specified, the current window is vertically split and narrow.
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2710 flags = WSP_HELP;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2711 if (cmdmod.split == 0 && curwin->w_width != Columns
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2712 && curwin->w_width < 80)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2713 flags |= WSP_TOP;
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2714 // If the user asks to open a new window, then copy the location list.
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2715 // Otherwise, don't copy the location list.
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2716 if (IS_LL_STACK(qi) && !newwin)
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2717 flags |= WSP_NEWLOC;
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2718
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2719 if (win_split(0, flags) == FAIL)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2720 return FAIL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2721
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2722 *opened_window = TRUE;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2723
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2724 if (curwin->w_height < p_hh)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2725 win_setheight((int)p_hh);
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2726
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2727 // When using location list, the new window should use the supplied
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2728 // location list. If the user asks to open a new window, then the new
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2729 // window will get a copy of the location list.
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2730 if (IS_LL_STACK(qi) && !newwin)
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2731 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2732 curwin->w_llist = qi;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2733 qi->qf_refcount++;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2734 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2735 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2736
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2737 if (!p_im)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2738 restart_edit = 0; // don't want insert mode in help file
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2739
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2740 return OK;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2741 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2742
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2743 /*
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2744 * Find a non-quickfix window using the given location list.
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2745 * Returns NULL if a matching window is not found.
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2746 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2747 static win_T *
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2748 qf_find_win_with_loclist(qf_info_T *ll)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2749 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2750 win_T *wp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2751
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2752 FOR_ALL_WINDOWS(wp)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2753 if (wp->w_llist == ll && !bt_quickfix(wp->w_buffer))
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2754 return wp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2755
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2756 return NULL;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2757 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2758
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2759 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2760 * Find a window containing a normal buffer
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2761 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2762 static win_T *
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2763 qf_find_win_with_normal_buf(void)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2764 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2765 win_T *wp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2766
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2767 FOR_ALL_WINDOWS(wp)
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2768 if (bt_normal(wp->w_buffer))
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2769 return wp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2770
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2771 return NULL;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2772 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2773
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2774 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2775 * Go to a window in any tabpage containing the specified file. Returns TRUE
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2776 * if successfully jumped to the window. Otherwise returns FALSE.
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2777 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2778 static int
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2779 qf_goto_tabwin_with_file(int fnum)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2780 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2781 tabpage_T *tp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2782 win_T *wp;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2783
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2784 FOR_ALL_TAB_WINDOWS(tp, wp)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2785 if (wp->w_buffer->b_fnum == fnum)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2786 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2787 goto_tabpage_win(tp, wp);
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2788 return TRUE;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2789 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2790
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2791 return FALSE;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2792 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2793
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2794 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2795 * Create a new window to show a file above the quickfix window. Called when
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2796 * only the quickfix window is present.
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2797 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2798 static int
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2799 qf_open_new_file_win(qf_info_T *ll_ref)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2800 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2801 int flags;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2802
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2803 flags = WSP_ABOVE;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2804 if (ll_ref != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2805 flags |= WSP_NEWLOC;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2806 if (win_split(0, flags) == FAIL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2807 return FAIL; // not enough room for window
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2808 p_swb = empty_option; // don't split again
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2809 swb_flags = 0;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2810 RESET_BINDING(curwin);
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2811 if (ll_ref != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2812 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2813 // The new window should use the location list from the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2814 // location list window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2815 curwin->w_llist = ll_ref;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2816 ll_ref->qf_refcount++;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2817 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2818 return OK;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2819 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2820
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2821 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2822 * Go to a window that shows the right buffer. If the window is not found, go
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2823 * to the window just above the location list window. This is used for opening
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2824 * a file from a location window and not from a quickfix window. If some usable
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2825 * window is previously found, then it is supplied in 'use_win'.
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2826 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2827 static void
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2828 qf_goto_win_with_ll_file(win_T *use_win, int qf_fnum, qf_info_T *ll_ref)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2829 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2830 win_T *win = use_win;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2831
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2832 if (win == NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2833 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2834 // Find the window showing the selected file
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2835 FOR_ALL_WINDOWS(win)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2836 if (win->w_buffer->b_fnum == qf_fnum)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2837 break;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2838 if (win == NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2839 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2840 // Find a previous usable window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2841 win = curwin;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2842 do
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2843 {
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2844 if (bt_normal(win->w_buffer))
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2845 break;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2846 if (win->w_prev == NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2847 win = lastwin; // wrap around the top
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2848 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2849 win = win->w_prev; // go to previous window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2850 } while (win != curwin);
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2851 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2852 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2853 win_goto(win);
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2854
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2855 // If the location list for the window is not set, then set it
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2856 // to the location list from the location window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2857 if (win->w_llist == NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2858 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2859 win->w_llist = ll_ref;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
2860 if (ll_ref != NULL)
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
2861 ll_ref->qf_refcount++;
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2862 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2863 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2864
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2865 /*
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2866 * Go to a window that contains the specified buffer 'qf_fnum'. If a window is
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2867 * not found, then go to the window just above the quickfix window. This is
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2868 * used for opening a file from a quickfix window and not from a location
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2869 * window.
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2870 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2871 static void
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2872 qf_goto_win_with_qfl_file(int qf_fnum)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2873 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2874 win_T *win;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2875 win_T *altwin;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2876
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2877 win = curwin;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2878 altwin = NULL;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2879 for (;;)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2880 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2881 if (win->w_buffer->b_fnum == qf_fnum)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2882 break;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2883 if (win->w_prev == NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2884 win = lastwin; // wrap around the top
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2885 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2886 win = win->w_prev; // go to previous window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2887
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2888 if (IS_QF_WINDOW(win))
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2889 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2890 // Didn't find it, go to the window before the quickfix
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2891 // window.
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2892 if (altwin != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2893 win = altwin;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2894 else if (curwin->w_prev != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2895 win = curwin->w_prev;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2896 else
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2897 win = curwin->w_next;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2898 break;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2899 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2900
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2901 // Remember a usable window.
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2902 if (altwin == NULL && !win->w_p_pvw && bt_normal(win->w_buffer))
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2903 altwin = win;
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2904 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2905
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2906 win_goto(win);
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2907 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2908
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2909 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2910 * Find a suitable window for opening a file (qf_fnum) from the
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2911 * quickfix/location list and jump to it. If the file is already opened in a
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2912 * window, jump to it. Otherwise open a new window to display the file. If
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2913 * 'newwin' is TRUE, then always open a new window. This is called from either
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2914 * a quickfix or a location list window.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2915 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2916 static int
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2917 qf_jump_to_usable_window(int qf_fnum, int newwin, int *opened_window)
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2918 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2919 win_T *usable_win_ptr = NULL;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2920 int usable_win;
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2921 qf_info_T *ll_ref = NULL;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2922 win_T *win;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2923
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2924 usable_win = 0;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2925
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2926 // If opening a new window, then don't use the location list referred by
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2927 // the current window. Otherwise two windows will refer to the same
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2928 // location list.
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2929 if (!newwin)
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2930 ll_ref = curwin->w_llist_ref;
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2931
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2932 if (ll_ref != NULL)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2933 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2934 // Find a non-quickfix window with this location list
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2935 usable_win_ptr = qf_find_win_with_loclist(ll_ref);
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2936 if (usable_win_ptr != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2937 usable_win = 1;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2938 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2939
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2940 if (!usable_win)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2941 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2942 // Locate a window showing a normal buffer
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2943 win = qf_find_win_with_normal_buf();
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2944 if (win != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2945 usable_win = 1;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2946 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2947
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2948 // If no usable window is found and 'switchbuf' contains "usetab"
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2949 // then search in other tabs.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2950 if (!usable_win && (swb_flags & SWB_USETAB))
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2951 usable_win = qf_goto_tabwin_with_file(qf_fnum);
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2952
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2953 // If there is only one window and it is the quickfix window, create a
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2954 // new one above the quickfix window.
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2955 if ((ONE_WINDOW && bt_quickfix(curbuf)) || !usable_win || newwin)
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2956 {
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2957 if (qf_open_new_file_win(ll_ref) != OK)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2958 return FAIL;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2959 *opened_window = TRUE; // close it when fail
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2960 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2961 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2962 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2963 if (curwin->w_llist_ref != NULL) // In a location window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2964 qf_goto_win_with_ll_file(usable_win_ptr, qf_fnum, ll_ref);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2965 else // In a quickfix window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2966 qf_goto_win_with_qfl_file(qf_fnum);
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2967 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2968
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2969 return OK;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2970 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2971
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2972 /*
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2973 * Edit the selected file or help file.
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2974 * Returns OK if successfully edited the file, FAIL on failing to open the
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2975 * buffer and NOTDONE if the quickfix/location list was freed by an autocmd
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2976 * when opening the buffer.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2977 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2978 static int
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2979 qf_jump_edit_buffer(
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2980 qf_info_T *qi,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2981 qfline_T *qf_ptr,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2982 int forceit,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2983 win_T *oldwin,
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2984 int *opened_window)
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2985 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2986 qf_list_T *qfl = &qi->qf_lists[qi->qf_curlist];
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2987 qfltype_T qfl_type = qfl->qfl_type;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2988 int retval = OK;
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
2989 int old_qf_curlist = qi->qf_curlist;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
2990 int save_qfid = qfl->qf_id;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2991
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2992 if (qf_ptr->qf_type == 1)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2993 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2994 // Open help file (do_ecmd() will set b_help flag, readfile() will
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2995 // set b_p_ro flag).
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2996 if (!can_abandon(curbuf, forceit))
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2997 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2998 no_write_message();
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
2999 return FAIL;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3000 }
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3001
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3002 retval = do_ecmd(qf_ptr->qf_fnum, NULL, NULL, NULL, (linenr_T)1,
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3003 ECMD_HIDE + ECMD_SET_HELP,
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3004 oldwin == curwin ? curwin : NULL);
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3005 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3006 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3007 retval = buflist_getfile(qf_ptr->qf_fnum,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3008 (linenr_T)1, GETF_SETMARK | GETF_SWITCH, forceit);
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
3009
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3010 // If a location list, check whether the associated window is still
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3011 // present.
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
3012 if (qfl_type == QFLT_LOCATION && !win_valid_any_tab(oldwin))
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3013 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3014 emsg(_("E924: Current window was closed"));
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3015 *opened_window = FALSE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3016 return NOTDONE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3017 }
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3018
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
3019 if (qfl_type == QFLT_QUICKFIX && !qflist_valid(NULL, save_qfid))
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3020 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3021 emsg(_("E925: Current quickfix was changed"));
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3022 return NOTDONE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3023 }
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3024
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3025 if (old_qf_curlist != qi->qf_curlist
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3026 || !is_qf_entry_present(qfl, qf_ptr))
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3027 {
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
3028 if (qfl_type == QFLT_QUICKFIX)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3029 emsg(_("E925: Current quickfix was changed"));
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3030 else
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3031 emsg(_(e_loc_list_changed));
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3032 return NOTDONE;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3033 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3034
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3035 return retval;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3036 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3037
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3038 /*
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
3039 * Go to the error line in the current file using either line/column number or
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
3040 * a search pattern.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3041 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3042 static void
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3043 qf_jump_goto_line(
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3044 linenr_T qf_lnum,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3045 int qf_col,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3046 char_u qf_viscol,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3047 char_u *qf_pattern)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3048 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3049 linenr_T i;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3050
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3051 if (qf_pattern == NULL)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3052 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3053 // Go to line with error, unless qf_lnum is 0.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3054 i = qf_lnum;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3055 if (i > 0)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3056 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3057 if (i > curbuf->b_ml.ml_line_count)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3058 i = curbuf->b_ml.ml_line_count;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3059 curwin->w_cursor.lnum = i;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3060 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3061 if (qf_col > 0)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3062 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3063 curwin->w_cursor.coladd = 0;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3064 if (qf_viscol == TRUE)
15703
b8a2362073bb patch 8.1.0859: "%v" in 'errorformat' does handle multi-byte characters
Bram Moolenaar <Bram@vim.org>
parents: 15641
diff changeset
3065 coladvance(qf_col - 1);
b8a2362073bb patch 8.1.0859: "%v" in 'errorformat' does handle multi-byte characters
Bram Moolenaar <Bram@vim.org>
parents: 15641
diff changeset
3066 else
b8a2362073bb patch 8.1.0859: "%v" in 'errorformat' does handle multi-byte characters
Bram Moolenaar <Bram@vim.org>
parents: 15641
diff changeset
3067 curwin->w_cursor.col = qf_col - 1;
14552
b298737a7188 patch 8.1.0289: cursor moves to wrong column after quickfix jump
Christian Brabandt <cb@256bit.org>
parents: 14550
diff changeset
3068 curwin->w_set_curswant = TRUE;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3069 check_cursor();
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3070 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3071 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3072 beginline(BL_WHITE | BL_FIX);
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3073 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3074 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3075 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3076 pos_T save_cursor;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3077
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3078 // Move the cursor to the first line in the buffer
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3079 save_cursor = curwin->w_cursor;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3080 curwin->w_cursor.lnum = 0;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3081 if (!do_search(NULL, '/', qf_pattern, (long)1,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3082 SEARCH_KEEP, NULL, NULL))
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3083 curwin->w_cursor = save_cursor;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3084 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3085 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3086
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3087 /*
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3088 * Display quickfix list index and size message
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3089 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3090 static void
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3091 qf_jump_print_msg(
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3092 qf_info_T *qi,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3093 int qf_index,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3094 qfline_T *qf_ptr,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3095 buf_T *old_curbuf,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3096 linenr_T old_lnum)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3097 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3098 linenr_T i;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3099 int len;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3100
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3101 // Update the screen before showing the message, unless the screen
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3102 // scrolled up.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3103 if (!msg_scrolled)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3104 update_topline_redraw();
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3105 sprintf((char *)IObuff, _("(%d of %d)%s%s: "), qf_index,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3106 qi->qf_lists[qi->qf_curlist].qf_count,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3107 qf_ptr->qf_cleared ? _(" (line deleted)") : "",
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3108 (char *)qf_types(qf_ptr->qf_type, qf_ptr->qf_nr));
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3109 // Add the message, skipping leading whitespace and newlines.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3110 len = (int)STRLEN(IObuff);
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3111 qf_fmt_text(skipwhite(qf_ptr->qf_text), IObuff + len, IOSIZE - len);
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3112
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3113 // Output the message. Overwrite to avoid scrolling when the 'O'
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3114 // flag is present in 'shortmess'; But when not jumping, print the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3115 // whole message.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3116 i = msg_scroll;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3117 if (curbuf == old_curbuf && curwin->w_cursor.lnum == old_lnum)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3118 msg_scroll = TRUE;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3119 else if (!msg_scrolled && shortmess(SHM_OVERALL))
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3120 msg_scroll = FALSE;
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3121 msg_attr_keep((char *)IObuff, 0, TRUE);
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3122 msg_scroll = i;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3123 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3124
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3125 /*
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3126 * Find a usable window for opening a file from the quickfix/location list. If
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3127 * a window is not found then open a new window. If 'newwin' is TRUE, then open
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3128 * a new window.
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3129 * Returns OK if successfully jumped or opened a window. Returns FAIL if not
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3130 * able to jump/open a window. Returns NOTDONE if a file is not associated
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3131 * with the entry.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3132 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3133 static int
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3134 qf_jump_open_window(
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3135 qf_info_T *qi,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3136 qfline_T *qf_ptr,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3137 int newwin,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3138 int *opened_window)
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3139 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3140 // For ":helpgrep" find a help window or open one.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3141 if (qf_ptr->qf_type == 1 && (!bt_help(curwin->w_buffer) || cmdmod.tab != 0))
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3142 if (jump_to_help_window(qi, newwin, opened_window) == FAIL)
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3143 return FAIL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3144
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3145 // If currently in the quickfix window, find another window to show the
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3146 // file in.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3147 if (bt_quickfix(curbuf) && !*opened_window)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3148 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3149 // If there is no file specified, we don't know where to go.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3150 // But do advance, otherwise ":cn" gets stuck.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3151 if (qf_ptr->qf_fnum == 0)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3152 return NOTDONE;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3153
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3154 if (qf_jump_to_usable_window(qf_ptr->qf_fnum, newwin,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3155 opened_window) == FAIL)
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3156 return FAIL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3157 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3158
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3159 return OK;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3160 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3161
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3162 /*
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3163 * Edit a selected file from the quickfix/location list and jump to a
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3164 * particular line/column, adjust the folds and display a message about the
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3165 * jump.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3166 * Returns OK on success and FAIL on failing to open the file/buffer. Returns
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3167 * NOTDONE if the quickfix/location list is freed by an autocmd when opening
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3168 * the file.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3169 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3170 static int
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3171 qf_jump_to_buffer(
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3172 qf_info_T *qi,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3173 int qf_index,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3174 qfline_T *qf_ptr,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3175 int forceit,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3176 win_T *oldwin,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3177 int *opened_window,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3178 int openfold,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3179 int print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3180 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3181 buf_T *old_curbuf;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3182 linenr_T old_lnum;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3183 int retval = OK;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3184
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3185 // If there is a file name, read the wanted file if needed, and check
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3186 // autowrite etc.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3187 old_curbuf = curbuf;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3188 old_lnum = curwin->w_cursor.lnum;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3189
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3190 if (qf_ptr->qf_fnum != 0)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3191 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3192 retval = qf_jump_edit_buffer(qi, qf_ptr, forceit, oldwin,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3193 opened_window);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3194 if (retval != OK)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3195 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3196 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3197
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3198 // When not switched to another buffer, still need to set pc mark
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3199 if (curbuf == old_curbuf)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3200 setpcmark();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3201
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3202 qf_jump_goto_line(qf_ptr->qf_lnum, qf_ptr->qf_col, qf_ptr->qf_viscol,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3203 qf_ptr->qf_pattern);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3204
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3205 #ifdef FEAT_FOLDING
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3206 if ((fdo_flags & FDO_QUICKFIX) && openfold)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3207 foldOpenCursor();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3208 #endif
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3209 if (print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3210 qf_jump_print_msg(qi, qf_index, qf_ptr, old_curbuf, old_lnum);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3211
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3212 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3213 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3214
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3215 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3216 * Jump to a quickfix line and try to use an existing window.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3217 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3218 void
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3219 qf_jump(qf_info_T *qi,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3220 int dir,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3221 int errornr,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3222 int forceit)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3223 {
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3224 qf_jump_newwin(qi, dir, errornr, forceit, FALSE);
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3225 }
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3226
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3227 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3228 * Jump to a quickfix line.
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3229 * If dir == 0 go to entry "errornr".
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3230 * If dir == FORWARD go "errornr" valid entries forward.
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3231 * If dir == BACKWARD go "errornr" valid entries backward.
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3232 * If dir == FORWARD_FILE go "errornr" valid entries files backward.
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3233 * If dir == BACKWARD_FILE go "errornr" valid entries files backward
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3234 * else if "errornr" is zero, redisplay the same line
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3235 * If 'forceit' is TRUE, then can discard changes to the current buffer.
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3236 * If 'newwin' is TRUE, then open the file in a new window.
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3237 */
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3238 void
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3239 qf_jump_newwin(qf_info_T *qi,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3240 int dir,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3241 int errornr,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3242 int forceit,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3243 int newwin)
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3244 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3245 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3246 qfline_T *qf_ptr;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3247 qfline_T *old_qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3248 int qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3249 int old_qf_index;
639
c79d4df4686e updated for version 7.0185
vimboss
parents: 634
diff changeset
3250 char_u *old_swb = p_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3251 unsigned old_swb_flags = swb_flags;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3252 int opened_window = FALSE;
1743
734d5bdae499 updated for version 7.2-041
vimboss
parents: 1683
diff changeset
3253 win_T *oldwin = curwin;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3254 int print_message = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3255 #ifdef FEAT_FOLDING
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3256 int old_KeyTyped = KeyTyped; // getting file may reset it
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3257 #endif
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3258 int retval = OK;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3259
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3260 if (qi == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3261 qi = &ql_info;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3262
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3263 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3264 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3265 emsg(_(e_quickfix));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3266 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3267 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3268
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3269 qfl = &qi->qf_lists[qi->qf_curlist];
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3270
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3271 qf_ptr = qfl->qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3272 old_qf_ptr = qf_ptr;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3273 qf_index = qfl->qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3274 old_qf_index = qf_index;
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3275
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3276 qf_ptr = qf_get_entry(qfl, errornr, dir, &qf_index);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3277 if (qf_ptr == NULL)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3278 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3279 qf_ptr = old_qf_ptr;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3280 qf_index = old_qf_index;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3281 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3282 }
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3283
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3284 qfl->qf_index = qf_index;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3285 if (qf_win_pos_update(qi, old_qf_index))
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3286 // No need to print the error message if it's visible in the error
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3287 // window
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3288 print_message = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3289
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3290 retval = qf_jump_open_window(qi, qf_ptr, newwin, &opened_window);
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3291 if (retval == FAIL)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3292 goto failed;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3293 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3294 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3295
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3296 retval = qf_jump_to_buffer(qi, qf_index, qf_ptr, forceit, oldwin,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3297 &opened_window, old_KeyTyped, print_message);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3298 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3299 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3300 // Quickfix/location list is freed by an autocmd
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3301 qi = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3302 qf_ptr = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3303 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3304
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3305 if (retval != OK)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3306 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3307 if (opened_window)
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3308 win_close(curwin, TRUE); // Close opened window
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3309 if (qf_ptr != NULL && qf_ptr->qf_fnum != 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3310 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3311 // Couldn't open file, so put index back where it was. This could
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3312 // happen if the file was readonly and we changed something.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3313 failed:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3314 qf_ptr = old_qf_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3315 qf_index = old_qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3316 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3317 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3318 theend:
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3319 if (qi != NULL)
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3320 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3321 qfl->qf_ptr = qf_ptr;
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3322 qfl->qf_index = qf_index;
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3323 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3324 if (p_swb != old_swb && opened_window)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3325 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3326 // Restore old 'switchbuf' value, but not when an autocommand or
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3327 // modeline has changed the value.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3328 if (p_swb == empty_option)
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3329 {
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3330 p_swb = old_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3331 swb_flags = old_swb_flags;
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3332 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3333 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3334 free_string_option(old_swb);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3335 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3336 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3337
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3338 // Highlight attributes used for displaying entries from the quickfix list.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3339 static int qfFileAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3340 static int qfSepAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3341 static int qfLineAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3342
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3343 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3344 * Display information about a single entry from the quickfix/location list.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3345 * Used by ":clist/:llist" commands.
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3346 * 'cursel' will be set to TRUE for the currently selected entry in the
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3347 * quickfix list.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3348 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3349 static void
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3350 qf_list_entry(qfline_T *qfp, int qf_idx, int cursel)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3351 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3352 char_u *fname;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3353 buf_T *buf;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3354 int filter_entry;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3355
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3356 fname = NULL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3357 if (qfp->qf_module != NULL && *qfp->qf_module != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3358 vim_snprintf((char *)IObuff, IOSIZE, "%2d %s", qf_idx,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3359 (char *)qfp->qf_module);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3360 else {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3361 if (qfp->qf_fnum != 0
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3362 && (buf = buflist_findnr(qfp->qf_fnum)) != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3363 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3364 fname = buf->b_fname;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3365 if (qfp->qf_type == 1) // :helpgrep
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3366 fname = gettail(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3367 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3368 if (fname == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3369 sprintf((char *)IObuff, "%2d", qf_idx);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3370 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3371 vim_snprintf((char *)IObuff, IOSIZE, "%2d %s",
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3372 qf_idx, (char *)fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3373 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3374
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3375 // Support for filtering entries using :filter /pat/ clist
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3376 // Match against the module name, file name, search pattern and
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3377 // text of the entry.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3378 filter_entry = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3379 if (qfp->qf_module != NULL && *qfp->qf_module != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3380 filter_entry &= message_filtered(qfp->qf_module);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3381 if (filter_entry && fname != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3382 filter_entry &= message_filtered(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3383 if (filter_entry && qfp->qf_pattern != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3384 filter_entry &= message_filtered(qfp->qf_pattern);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3385 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3386 filter_entry &= message_filtered(qfp->qf_text);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3387 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3388 return;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3389
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3390 msg_putchar('\n');
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3391 msg_outtrans_attr(IObuff, cursel ? HL_ATTR(HLF_QFL) : qfFileAttr);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3392
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3393 if (qfp->qf_lnum != 0)
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3394 msg_puts_attr(":", qfSepAttr);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3395 if (qfp->qf_lnum == 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3396 IObuff[0] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3397 else if (qfp->qf_col == 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3398 sprintf((char *)IObuff, "%ld", qfp->qf_lnum);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3399 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3400 sprintf((char *)IObuff, "%ld col %d",
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3401 qfp->qf_lnum, qfp->qf_col);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3402 sprintf((char *)IObuff + STRLEN(IObuff), "%s",
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3403 (char *)qf_types(qfp->qf_type, qfp->qf_nr));
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3404 msg_puts_attr((char *)IObuff, qfLineAttr);
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3405 msg_puts_attr(":", qfSepAttr);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3406 if (qfp->qf_pattern != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3407 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3408 qf_fmt_text(qfp->qf_pattern, IObuff, IOSIZE);
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3409 msg_puts((char *)IObuff);
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3410 msg_puts_attr(":", qfSepAttr);
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3411 }
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3412 msg_puts(" ");
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3413
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3414 // Remove newlines and leading whitespace from the text. For an
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3415 // unrecognized line keep the indent, the compiler may mark a word
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3416 // with ^^^^.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3417 qf_fmt_text((fname != NULL || qfp->qf_lnum != 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3418 ? skipwhite(qfp->qf_text) : qfp->qf_text,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3419 IObuff, IOSIZE);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3420 msg_prt_line(IObuff, FALSE);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3421 out_flush(); // show one line at a time
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3422 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3423
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3424 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3425 * ":clist": list all errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3426 * ":llist": list all locations
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3427 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3428 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3429 qf_list(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3430 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3431 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3432 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3433 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3434 int idx1 = 1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3435 int idx2 = -1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3436 char_u *arg = eap->arg;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3437 int plus = FALSE;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3438 int all = eap->forceit; // if not :cl!, only show
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3439 // recognised errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3440 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3441
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3442 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3443 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3444 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3445 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3446 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3447 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3448 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3449 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3450 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3451
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3452 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3453 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3454 emsg(_(e_quickfix));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3455 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3456 }
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3457 if (*arg == '+')
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3458 {
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3459 ++arg;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3460 plus = TRUE;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3461 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3462 if (!get_list_range(&arg, &idx1, &idx2) || *arg != NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3463 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3464 emsg(_(e_trailing));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3465 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3466 }
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3467 qfl = &qi->qf_lists[qi->qf_curlist];
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3468 if (plus)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3469 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3470 i = qfl->qf_index;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3471 idx2 = i + idx1;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3472 idx1 = i;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3473 }
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3474 else
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3475 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3476 i = qfl->qf_count;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3477 if (idx1 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3478 idx1 = (-idx1 > i) ? 0 : idx1 + i + 1;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3479 if (idx2 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3480 idx2 = (-idx2 > i) ? 0 : idx2 + i + 1;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3481 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3482
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3483 // Shorten all the file names, so that it is easy to read
13819
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
3484 shorten_fnames(FALSE);
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
3485
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3486 // Get the attributes for the different quickfix highlight items. Note
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3487 // that this depends on syntax items defined in the qf.vim syntax file
12912
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3488 qfFileAttr = syn_name2attr((char_u *)"qfFileName");
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3489 if (qfFileAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3490 qfFileAttr = HL_ATTR(HLF_D);
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3491 qfSepAttr = syn_name2attr((char_u *)"qfSeparator");
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3492 if (qfSepAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3493 qfSepAttr = HL_ATTR(HLF_D);
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3494 qfLineAttr = syn_name2attr((char_u *)"qfLineNr");
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3495 if (qfLineAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3496 qfLineAttr = HL_ATTR(HLF_N);
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3497
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3498 if (qfl->qf_nonevalid)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3499 all = TRUE;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3500 qfp = qfl->qf_start;
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3501 for (i = 1; !got_int && i <= qfl->qf_count; )
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3502 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3503 if ((qfp->qf_valid || all) && idx1 <= i && i <= idx2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3504 {
2047
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3505 if (got_int)
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3506 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3507
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3508 qf_list_entry(qfp, i, i == qfl->qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3509 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3510
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3511 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3512 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3513 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3514 ++i;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3515 ui_breakcheck();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3516 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3517 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3518
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3519 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3520 * Remove newlines and leading whitespace from an error message.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3521 * Put the result in "buf[bufsize]".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3522 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3523 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3524 qf_fmt_text(char_u *text, char_u *buf, int bufsize)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3525 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3526 int i;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3527 char_u *p = text;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3528
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3529 for (i = 0; *p != NUL && i < bufsize - 1; ++i)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3530 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3531 if (*p == '\n')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3532 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3533 buf[i] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3534 while (*++p != NUL)
11129
f4ea50924c6d patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents: 11063
diff changeset
3535 if (!VIM_ISWHITE(*p) && *p != '\n')
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3536 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3537 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3538 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3539 buf[i] = *p++;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3540 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3541 buf[i] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3542 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3543
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3544 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3545 * Display information (list number, list size and the title) about a
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3546 * quickfix/location list.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3547 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3548 static void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3549 qf_msg(qf_info_T *qi, int which, char *lead)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3550 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3551 char *title = (char *)qi->qf_lists[which].qf_title;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3552 int count = qi->qf_lists[which].qf_count;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3553 char_u buf[IOSIZE];
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3554
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3555 vim_snprintf((char *)buf, IOSIZE, _("%serror list %d of %d; %d errors "),
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3556 lead,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3557 which + 1,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3558 qi->qf_listcount,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3559 count);
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3560
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3561 if (title != NULL)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3562 {
9579
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3563 size_t len = STRLEN(buf);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3564
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3565 if (len < 34)
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3566 {
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3567 vim_memset(buf + len, ' ', 34 - len);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3568 buf[34] = NUL;
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3569 }
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3570 vim_strcat(buf, (char_u *)title, IOSIZE);
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3571 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3572 trunc_string(buf, buf, Columns - 1, IOSIZE);
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3573 msg((char *)buf);
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3574 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3575
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3576 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3577 * ":colder [count]": Up in the quickfix stack.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3578 * ":cnewer [count]": Down in the quickfix stack.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3579 * ":lolder [count]": Up in the location list stack.
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3580 * ":lnewer [count]": Down in the location list stack.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3581 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3582 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3583 qf_age(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3584 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3585 qf_info_T *qi = &ql_info;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3586 int count;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3587
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3588 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3589 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3590 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3591 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3592 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3593 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3594 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3595 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3596 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3597
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3598 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3599 count = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3600 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3601 count = 1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3602 while (count--)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3603 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3604 if (eap->cmdidx == CMD_colder || eap->cmdidx == CMD_lolder)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3605 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3606 if (qi->qf_curlist == 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3607 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3608 emsg(_("E380: At bottom of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3609 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3610 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3611 --qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3612 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3613 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3614 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3615 if (qi->qf_curlist >= qi->qf_listcount - 1)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3616 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3617 emsg(_("E381: At top of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3618 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3619 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3620 ++qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3621 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3622 }
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3623 qf_msg(qi, qi->qf_curlist, "");
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
3624 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3625 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3626
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3627 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3628 * Display the information about all the quickfix/location lists in the stack
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3629 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3630 void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3631 qf_history(exarg_T *eap)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3632 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3633 qf_info_T *qi = &ql_info;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3634 int i;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3635
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3636 if (is_loclist_cmd(eap->cmdidx))
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3637 qi = GET_LOC_LIST(curwin);
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3638 if (qf_stack_empty(qi))
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3639 msg(_("No entries"));
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3640 else
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3641 for (i = 0; i < qi->qf_listcount; ++i)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3642 qf_msg(qi, i, i == qi->qf_curlist ? "> " : " ");
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3643 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3644
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3645 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3646 * Free all the entries in the error list "idx". Note that other information
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3647 * associated with the list like context and title are not freed.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3648 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3649 static void
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3650 qf_free_items(qf_list_T *qfl)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3651 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3652 qfline_T *qfp;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3653 qfline_T *qfpnext;
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3654 int stop = FALSE;
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3655
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3656 while (qfl->qf_count && qfl->qf_start != NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3657 {
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3658 qfp = qfl->qf_start;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3659 qfpnext = qfp->qf_next;
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
3660 if (!stop)
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3661 {
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
3662 vim_free(qfp->qf_module);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3663 vim_free(qfp->qf_text);
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
3664 vim_free(qfp->qf_pattern);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3665 stop = (qfp == qfpnext);
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3666 vim_free(qfp);
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3667 if (stop)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3668 // Somehow qf_count may have an incorrect value, set it to 1
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3669 // to avoid crashing when it's wrong.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3670 // TODO: Avoid qf_count being incorrect.
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3671 qfl->qf_count = 1;
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3672 }
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3673 qfl->qf_start = qfpnext;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3674 --qfl->qf_count;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3675 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3676
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3677 qfl->qf_index = 0;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3678 qfl->qf_start = NULL;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3679 qfl->qf_last = NULL;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3680 qfl->qf_ptr = NULL;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3681 qfl->qf_nonevalid = TRUE;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3682
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3683 qf_clean_dir_stack(&qfl->qf_dir_stack);
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3684 qfl->qf_directory = NULL;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3685 qf_clean_dir_stack(&qfl->qf_file_stack);
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3686 qfl->qf_currfile = NULL;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3687 qfl->qf_multiline = FALSE;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3688 qfl->qf_multiignore = FALSE;
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3689 qfl->qf_multiscan = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3690 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3691
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3692 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3693 * Free error list "idx". Frees all the entries in the quickfix list,
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3694 * associated context information and the title.
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3695 */
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3696 static void
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3697 qf_free(qf_list_T *qfl)
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3698 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3699 qf_free_items(qfl);
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3700
13244
ac42c4b11dbc patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents: 13115
diff changeset
3701 VIM_CLEAR(qfl->qf_title);
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3702 free_tv(qfl->qf_ctx);
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3703 qfl->qf_ctx = NULL;
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
3704 qfl->qf_id = 0;
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
3705 qfl->qf_changedtick = 0L;
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3706 }
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3707
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3708 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3709 * qf_mark_adjust: adjust marks
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3710 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3711 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3712 qf_mark_adjust(
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3713 win_T *wp,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3714 linenr_T line1,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3715 linenr_T line2,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3716 long amount,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3717 long amount_after)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3718 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3719 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3720 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3721 int idx;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3722 qf_info_T *qi = &ql_info;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3723 int found_one = FALSE;
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3724 int buf_has_flag = wp == NULL ? BUF_HAS_QF_ENTRY : BUF_HAS_LL_ENTRY;
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3725
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3726 if (!(curbuf->b_has_qf_entry & buf_has_flag))
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3727 return;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3728 if (wp != NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3729 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3730 if (wp->w_llist == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3731 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3732 qi = wp->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3733 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3734
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3735 for (idx = 0; idx < qi->qf_listcount; ++idx)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3736 if (!qf_list_empty(qi, idx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3737 for (i = 0, qfp = qi->qf_lists[idx].qf_start;
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3738 i < qi->qf_lists[idx].qf_count && qfp != NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3739 ++i, qfp = qfp->qf_next)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3740 if (qfp->qf_fnum == curbuf->b_fnum)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3741 {
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3742 found_one = TRUE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3743 if (qfp->qf_lnum >= line1 && qfp->qf_lnum <= line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3744 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3745 if (amount == MAXLNUM)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3746 qfp->qf_cleared = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3747 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3748 qfp->qf_lnum += amount;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3749 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3750 else if (amount_after && qfp->qf_lnum > line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3751 qfp->qf_lnum += amount_after;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3752 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3753
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3754 if (!found_one)
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3755 curbuf->b_has_qf_entry &= ~buf_has_flag;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3756 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3757
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3758 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3759 * Make a nice message out of the error character and the error number:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3760 * char number message
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3761 * e or E 0 " error"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3762 * w or W 0 " warning"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3763 * i or I 0 " info"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3764 * 0 0 ""
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3765 * other 0 " c"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3766 * e or E n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3767 * w or W n " warning n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3768 * i or I n " info n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3769 * 0 n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3770 * other n " c n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3771 * 1 x "" :helpgrep
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3772 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3773 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3774 qf_types(int c, int nr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3775 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3776 static char_u buf[20];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3777 static char_u cc[3];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3778 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3779
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3780 if (c == 'W' || c == 'w')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3781 p = (char_u *)" warning";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3782 else if (c == 'I' || c == 'i')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3783 p = (char_u *)" info";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3784 else if (c == 'E' || c == 'e' || (c == 0 && nr > 0))
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3785 p = (char_u *)" error";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3786 else if (c == 0 || c == 1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3787 p = (char_u *)"";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3788 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3789 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3790 cc[0] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3791 cc[1] = c;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3792 cc[2] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3793 p = cc;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3794 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3795
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3796 if (nr <= 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3797 return p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3798
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3799 sprintf((char *)buf, "%s %3d", (char *)p, nr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3800 return buf;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3801 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3802
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3803 /*
14397
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3804 * When "split" is FALSE: Open the entry/result under the cursor.
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3805 * When "split" is TRUE: Open the entry/result under the cursor in a new window.
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3806 */
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3807 void
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3808 qf_view_result(int split)
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3809 {
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3810 qf_info_T *qi = &ql_info;
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3811
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3812 if (!bt_quickfix(curbuf))
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3813 return;
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3814
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3815 if (IS_LL_WINDOW(curwin))
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3816 qi = GET_LOC_LIST(curwin);
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3817
14491
9df0fcbfebb2 patch 8.1.0259: no test for fixed quickfix issue
Christian Brabandt <cb@256bit.org>
parents: 14477
diff changeset
3818 if (qf_list_empty(qi, qi->qf_curlist))
14397
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3819 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3820 emsg(_(e_quickfix));
14397
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3821 return;
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3822 }
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3823
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3824 if (split)
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3825 {
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3826 // Open the selected entry in a new window
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3827 qf_jump_newwin(qi, 0, (long)curwin->w_cursor.lnum, FALSE, TRUE);
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3828 do_cmdline_cmd((char_u *) "clearjumps");
14397
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3829 return;
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3830 }
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3831
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3832 do_cmdline_cmd((char_u *)(IS_LL_WINDOW(curwin) ? ".ll" : ".cc"));
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3833 }
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3834
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3835 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3836 * ":cwindow": open the quickfix window if we have errors to display,
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3837 * close it if not.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3838 * ":lwindow": open the location list window if we have locations to display,
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3839 * close it if not.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3840 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3841 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3842 ex_cwindow(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3843 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3844 qf_info_T *qi = &ql_info;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
3845 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3846 win_T *win;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3847
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3848 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3849 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3850 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3851 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3852 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3853 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3854
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
3855 qfl = &qi->qf_lists[qi->qf_curlist];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
3856
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3857 // Look for an existing quickfix window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3858 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3859
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3860 // If a quickfix window is open but we have no errors to display,
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3861 // close the window. If a quickfix window is not open, then open
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3862 // it if we have errors; otherwise, leave it closed.
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3863 if (qf_stack_empty(qi)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
3864 || qfl->qf_nonevalid
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3865 || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3866 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3867 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3868 ex_cclose(eap);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3869 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3870 else if (win == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3871 ex_copen(eap);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3872 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3873
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3874 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3875 * ":cclose": close the window showing the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3876 * ":lclose": close the window showing the location list
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3877 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3878 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3879 ex_cclose(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3880 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3881 win_T *win = NULL;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3882 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3883
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3884 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3885 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3886 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3887 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3888 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3889 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3890
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3891 // Find existing quickfix window and close it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3892 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3893 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3894 win_close(win, FALSE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3895 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3896
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3897 /*
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3898 * Set "w:quickfix_title" if "qi" has a title.
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3899 */
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3900 static void
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3901 qf_set_title_var(qf_list_T *qfl)
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3902 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3903 if (qfl->qf_title != NULL)
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3904 set_internal_string_var((char_u *)"w:quickfix_title", qfl->qf_title);
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3905 }
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3906
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3907 /*
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3908 * Goto a quickfix or location list window (if present).
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3909 * Returns OK if the window is found, FAIL otherwise.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3910 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3911 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3912 qf_goto_cwindow(qf_info_T *qi, int resize, int sz, int vertsplit)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3913 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3914 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3915
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3916 win = qf_find_win(qi);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3917 if (win == NULL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3918 return FAIL;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3919
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3920 win_goto(win);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3921 if (resize)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3922 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3923 if (vertsplit)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3924 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3925 if (sz != win->w_width)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3926 win_setwidth(sz);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3927 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3928 else if (sz != win->w_height)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3929 win_setheight(sz);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3930 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3931
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3932 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3933 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3934
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3935 /*
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3936 * Open a new quickfix or location list window, load the quickfix buffer and
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3937 * set the appropriate options for the window.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3938 * Returns FAIL if the window could not be opened.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3939 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3940 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3941 qf_open_new_cwindow(qf_info_T *qi, int height)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3942 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3943 buf_T *qf_buf;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3944 win_T *oldwin = curwin;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3945 tabpage_T *prevtab = curtab;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3946 int flags = 0;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3947 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3948
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3949 qf_buf = qf_find_buf(qi);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3950
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3951 // The current window becomes the previous window afterwards.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3952 win = curwin;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3953
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3954 if (IS_QF_STACK(qi) && cmdmod.split == 0)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3955 // Create the new quickfix window at the very bottom, except when
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3956 // :belowright or :aboveleft is used.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3957 win_goto(lastwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3958 // Default is to open the window below the current window
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3959 if (cmdmod.split == 0)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3960 flags = WSP_BELOW;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3961 flags |= WSP_NEWLOC;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3962 if (win_split(height, flags) == FAIL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3963 return FAIL; // not enough room for window
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3964 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3965
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3966 if (IS_LL_STACK(qi))
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3967 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3968 // For the location list window, create a reference to the
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3969 // location list from the window 'win'.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3970 curwin->w_llist_ref = win->w_llist;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3971 win->w_llist->qf_refcount++;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3972 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3973
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3974 if (oldwin != curwin)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3975 oldwin = NULL; // don't store info when in another window
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3976 if (qf_buf != NULL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3977 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3978 // Use the existing quickfix buffer
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3979 (void)do_ecmd(qf_buf->b_fnum, NULL, NULL, NULL, ECMD_ONE,
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3980 ECMD_HIDE + ECMD_OLDBUF, oldwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3981 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3982 else
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3983 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3984 // Create a new quickfix buffer
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3985 (void)do_ecmd(0, NULL, NULL, NULL, ECMD_ONE, ECMD_HIDE, oldwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3986
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3987 // switch off 'swapfile'
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3988 set_option_value((char_u *)"swf", 0L, NULL, OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3989 set_option_value((char_u *)"bt", 0L, (char_u *)"quickfix",
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3990 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3991 set_option_value((char_u *)"bh", 0L, (char_u *)"wipe", OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3992 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3993 #ifdef FEAT_DIFF
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3994 curwin->w_p_diff = FALSE;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3995 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3996 #ifdef FEAT_FOLDING
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3997 set_option_value((char_u *)"fdm", 0L, (char_u *)"manual",
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3998 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3999 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4000 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4001
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4002 // Only set the height when still in the same tab page and there is no
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4003 // window to the side.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4004 if (curtab == prevtab && curwin->w_width == Columns)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4005 win_setheight(height);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4006 curwin->w_p_wfh = TRUE; // set 'winfixheight'
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4007 if (win_valid(win))
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4008 prevwin = win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4009
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4010 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4011 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4012
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4013 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4014 * ":copen": open a window that shows the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4015 * ":lopen": open a window that shows the location list.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4016 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4017 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4018 ex_copen(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4019 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4020 qf_info_T *qi = &ql_info;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4021 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4022 int height;
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4023 int status = FAIL;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4024 int lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4025
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4026 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4027 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4028 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4029 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4030 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4031 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4032 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4033 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4034 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4035
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4036 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4037
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4038 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4039 height = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4040 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4041 height = QF_WINHEIGHT;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4042
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4043 reset_VIsual_and_resel(); // stop Visual mode
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4044 #ifdef FEAT_GUI
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4045 need_mouse_correct = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4046 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4047
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4048 // Find an existing quickfix window, or open a new one.
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4049 if (cmdmod.tab == 0)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4050 status = qf_goto_cwindow(qi, eap->addr_count != 0, height,
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4051 cmdmod.split & WSP_VERT);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4052 if (status == FAIL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4053 if (qf_open_new_cwindow(qi, height) == FAIL)
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4054 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4055 decr_quickfix_busy();
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4056 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4057 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4058
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4059 qfl = &qi->qf_lists[qi->qf_curlist];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4060 qf_set_title_var(qfl);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4061 // Save the current index here, as updating the quickfix buffer may free
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4062 // the quickfix list
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4063 lnum = qfl->qf_index;
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4064
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4065 // Fill the buffer with the quickfix list.
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4066 qf_fill_buffer(qi, curbuf, NULL);
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4067
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4068 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4069
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4070 curwin->w_cursor.lnum = lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4071 curwin->w_cursor.col = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4072 check_cursor();
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4073 update_topline(); // scroll to show the line
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4074 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4075
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4076 /*
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4077 * Move the cursor in the quickfix window to "lnum".
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4078 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4079 static void
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4080 qf_win_goto(win_T *win, linenr_T lnum)
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4081 {
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4082 win_T *old_curwin = curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4083
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4084 curwin = win;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4085 curbuf = win->w_buffer;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4086 curwin->w_cursor.lnum = lnum;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4087 curwin->w_cursor.col = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4088 curwin->w_cursor.coladd = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4089 curwin->w_curswant = 0;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4090 update_topline(); // scroll to show the line
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4091 redraw_later(VALID);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4092 curwin->w_redr_status = TRUE; // update ruler
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4093 curwin = old_curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4094 curbuf = curwin->w_buffer;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4095 }
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4096
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4097 /*
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4098 * :cbottom/:lbottom commands.
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4099 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4100 void
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4101 ex_cbottom(exarg_T *eap)
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4102 {
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4103 qf_info_T *qi = &ql_info;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4104 win_T *win;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4105
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4106 if (is_loclist_cmd(eap->cmdidx))
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4107 {
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4108 qi = GET_LOC_LIST(curwin);
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4109 if (qi == NULL)
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4110 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4111 emsg(_(e_loclist));
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4112 return;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4113 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4114 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4115
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4116 win = qf_find_win(qi);
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4117 if (win != NULL && win->w_cursor.lnum != win->w_buffer->b_ml.ml_line_count)
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4118 qf_win_goto(win, win->w_buffer->b_ml.ml_line_count);
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4119 }
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4120
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4121 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4122 * Return the number of the current entry (line number in the quickfix
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4123 * window).
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4124 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4125 linenr_T
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4126 qf_current_entry(win_T *wp)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4127 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4128 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4129
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4130 if (IS_LL_WINDOW(wp))
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4131 // In the location list window, use the referenced location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4132 qi = wp->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4133
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4134 return qi->qf_lists[qi->qf_curlist].qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4135 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4136
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4137 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4138 * Update the cursor position in the quickfix window to the current error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4139 * Return TRUE if there is a quickfix window.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4140 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4141 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4142 qf_win_pos_update(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4143 qf_info_T *qi,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4144 int old_qf_index) // previous qf_index or zero
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4145 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4146 win_T *win;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4147 int qf_index = qi->qf_lists[qi->qf_curlist].qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4148
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4149 // Put the cursor on the current error in the quickfix window, so that
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4150 // it's viewable.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4151 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4152 if (win != NULL
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4153 && qf_index <= win->w_buffer->b_ml.ml_line_count
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4154 && old_qf_index != qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4155 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4156 if (qf_index > old_qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4157 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4158 win->w_redraw_top = old_qf_index;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4159 win->w_redraw_bot = qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4160 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4161 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4162 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4163 win->w_redraw_top = qf_index;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4164 win->w_redraw_bot = old_qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4165 }
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4166 qf_win_goto(win, qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4167 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4168 return win != NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4169 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4170
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4171 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4172 * Check whether the given window is displaying the specified quickfix/location
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
4173 * stack.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4174 */
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4175 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4176 is_qf_win(win_T *win, qf_info_T *qi)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4177 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4178 // A window displaying the quickfix buffer will have the w_llist_ref field
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4179 // set to NULL.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4180 // A window displaying a location list buffer will have the w_llist_ref
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4181 // pointing to the location list.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4182 if (bt_quickfix(win->w_buffer))
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
4183 if ((IS_QF_STACK(qi) && win->w_llist_ref == NULL)
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
4184 || (IS_LL_STACK(qi) && win->w_llist_ref == qi))
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4185 return TRUE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4186
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4187 return FALSE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4188 }
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4189
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4190 /*
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
4191 * Find a window displaying the quickfix/location stack 'qi'
13115
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
4192 * Only searches in the current tabpage.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4193 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4194 static win_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4195 qf_find_win(qf_info_T *qi)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4196 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4197 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4198
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4199 FOR_ALL_WINDOWS(win)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4200 if (is_qf_win(win, qi))
13115
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
4201 return win;
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
4202 return NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4203 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4204
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4205 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4206 * Find a quickfix buffer.
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4207 * Searches in windows opened in all the tabs.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4208 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4209 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4210 qf_find_buf(qf_info_T *qi)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4211 {
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4212 tabpage_T *tp;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4213 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4214
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4215 FOR_ALL_TAB_WINDOWS(tp, win)
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4216 if (is_qf_win(win, qi))
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4217 return win->w_buffer;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4218
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4219 return NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4220 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4221
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4222 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4223 * Update the w:quickfix_title variable in the quickfix/location list window
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4224 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4225 static void
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4226 qf_update_win_titlevar(qf_info_T *qi)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4227 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4228 win_T *win;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4229 win_T *curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4230
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4231 if ((win = qf_find_win(qi)) != NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4232 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4233 curwin_save = curwin;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4234 curwin = win;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
4235 qf_set_title_var(&qi->qf_lists[qi->qf_curlist]);
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4236 curwin = curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4237 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4238 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4239
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4240 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4241 * Find the quickfix buffer. If it exists, update the contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4242 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4243 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4244 qf_update_buffer(qf_info_T *qi, qfline_T *old_last)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4245 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4246 buf_T *buf;
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4247 win_T *win;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4248 aco_save_T aco;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4249
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4250 // Check if a buffer for the quickfix list exists. Update it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4251 buf = qf_find_buf(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4252 if (buf != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4253 {
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4254 linenr_T old_line_count = buf->b_ml.ml_line_count;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4255
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4256 if (old_last == NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4257 // set curwin/curbuf to buf and save a few things
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4258 aucmd_prepbuf(&aco, buf);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4259
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4260 qf_update_win_titlevar(qi);
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4261
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4262 qf_fill_buffer(qi, buf, old_last);
11705
c43118ecb0a3 patch 8.0.0735: no indication that the quickfix window/buffer changed
Christian Brabandt <cb@256bit.org>
parents: 11700
diff changeset
4263 ++CHANGEDTICK(buf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4264
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4265 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4266 {
8932
25c2031e9f9f commit https://github.com/vim/vim/commit/c1808d5822ed9534ef7f0fe509b15bee92a5cc28
Christian Brabandt <cb@256bit.org>
parents: 8751
diff changeset
4267 (void)qf_win_pos_update(qi, 0);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4268
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4269 // restore curwin/curbuf and a few other things
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4270 aucmd_restbuf(&aco);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4271 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4272
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4273 // Only redraw when added lines are visible. This avoids flickering
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4274 // when the added lines are not visible.
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4275 if ((win = qf_find_win(qi)) != NULL && old_line_count < win->w_botline)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4276 redraw_buf_later(buf, NOT_VALID);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4277 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4278 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4279
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4280 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4281 * Add an error line to the quickfix buffer.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4282 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4283 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4284 qf_buf_add_line(buf_T *buf, linenr_T lnum, qfline_T *qfp, char_u *dirname)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4285 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4286 int len;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4287 buf_T *errbuf;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4288
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4289 if (qfp->qf_module != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4290 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4291 STRCPY(IObuff, qfp->qf_module);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4292 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4293 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4294 else if (qfp->qf_fnum != 0
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4295 && (errbuf = buflist_findnr(qfp->qf_fnum)) != NULL
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4296 && errbuf->b_fname != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4297 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4298 if (qfp->qf_type == 1) // :helpgrep
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4299 STRCPY(IObuff, gettail(errbuf->b_fname));
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4300 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4301 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4302 // shorten the file name if not done already
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4303 if (errbuf->b_sfname == NULL
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4304 || mch_isFullName(errbuf->b_sfname))
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4305 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4306 if (*dirname == NUL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4307 mch_dirname(dirname, MAXPATHL);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4308 shorten_buf_fname(errbuf, dirname, FALSE);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4309 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4310 STRCPY(IObuff, errbuf->b_fname);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4311 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4312 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4313 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4314 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4315 len = 0;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4316 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4317
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4318 if (qfp->qf_lnum > 0)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4319 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4320 sprintf((char *)IObuff + len, "%ld", qfp->qf_lnum);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4321 len += (int)STRLEN(IObuff + len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4322
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4323 if (qfp->qf_col > 0)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4324 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4325 sprintf((char *)IObuff + len, " col %d", qfp->qf_col);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4326 len += (int)STRLEN(IObuff + len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4327 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4328
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4329 sprintf((char *)IObuff + len, "%s",
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4330 (char *)qf_types(qfp->qf_type, qfp->qf_nr));
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4331 len += (int)STRLEN(IObuff + len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4332 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4333 else if (qfp->qf_pattern != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4334 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4335 qf_fmt_text(qfp->qf_pattern, IObuff + len, IOSIZE - len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4336 len += (int)STRLEN(IObuff + len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4337 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4338 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4339 IObuff[len++] = ' ';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4340
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4341 // Remove newlines and leading whitespace from the text.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4342 // For an unrecognized line keep the indent, the compiler may
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4343 // mark a word with ^^^^.
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4344 qf_fmt_text(len > 3 ? skipwhite(qfp->qf_text) : qfp->qf_text,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4345 IObuff + len, IOSIZE - len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4346
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4347 if (ml_append_buf(buf, lnum, IObuff,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4348 (colnr_T)STRLEN(IObuff) + 1, FALSE) == FAIL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4349 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4350
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4351 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4352 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4353
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4354 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4355 * Fill current buffer with quickfix errors, replacing any previous contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4356 * curbuf must be the quickfix buffer!
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4357 * If "old_last" is not NULL append the items after this one.
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4358 * When "old_last" is NULL then "buf" must equal "curbuf"! Because
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4359 * ml_delete() is used and autocommands will be triggered.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4360 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4361 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4362 qf_fill_buffer(qf_info_T *qi, buf_T *buf, qfline_T *old_last)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4363 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4364 linenr_T lnum;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4365 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4366 int old_KeyTyped = KeyTyped;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4367
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4368 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4369 {
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4370 if (buf != curbuf)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4371 {
10359
66f1b5bf3fa6 commit https://github.com/vim/vim/commit/95f096030ed1a8afea028f2ea295d6f6a70f466f
Christian Brabandt <cb@256bit.org>
parents: 10349
diff changeset
4372 internal_error("qf_fill_buffer()");
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4373 return;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4374 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4375
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4376 // delete all existing lines
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4377 while ((curbuf->b_ml.ml_flags & ML_EMPTY) == 0)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4378 (void)ml_delete((linenr_T)1, FALSE);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4379 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4380
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4381 // Check if there is anything to display
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
4382 if (!qf_stack_empty(qi))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4383 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4384 qf_list_T *qfl = &qi->qf_lists[qi->qf_curlist];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4385 char_u dirname[MAXPATHL];
13819
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4386
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4387 *dirname = NUL;
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4388
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4389 // Add one line for each error
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4390 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4391 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4392 qfp = qfl->qf_start;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4393 lnum = 0;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4394 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4395 else
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4396 {
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4397 qfp = old_last->qf_next;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4398 lnum = buf->b_ml.ml_line_count;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4399 }
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4400 while (lnum < qfl->qf_count)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4401 {
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4402 if (qf_buf_add_line(buf, lnum, qfp, dirname) == FAIL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4403 break;
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4404
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4405 ++lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4406 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4407 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4408 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4409 }
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4410
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4411 if (old_last == NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4412 // Delete the empty line which is now at the end
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4413 (void)ml_delete(lnum + 1, FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4414 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4415
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4416 // correct cursor position
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4417 check_lnums(TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4418
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4419 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4420 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4421 // Set the 'filetype' to "qf" each time after filling the buffer.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4422 // This resembles reading a file into a buffer, it's more logical when
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4423 // using autocommands.
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4424 ++curbuf_lock;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4425 set_option_value((char_u *)"ft", 0L, (char_u *)"qf", OPT_LOCAL);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4426 curbuf->b_p_ma = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4427
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4428 keep_filetype = TRUE; // don't detect 'filetype'
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4429 apply_autocmds(EVENT_BUFREADPOST, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4430 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4431 apply_autocmds(EVENT_BUFWINENTER, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4432 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4433 keep_filetype = FALSE;
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4434 --curbuf_lock;
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
4435
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4436 // make sure it will be redrawn
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4437 redraw_curbuf_later(NOT_VALID);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4438 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4439
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4440 // Restore KeyTyped, setting 'filetype' may reset it.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4441 KeyTyped = old_KeyTyped;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4442 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4443
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4444 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4445 * For every change made to the quickfix list, update the changed tick.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4446 */
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4447 static void
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4448 qf_list_changed(qf_list_T *qfl)
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4449 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4450 qfl->qf_changedtick++;
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4451 }
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4452
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4453 /*
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4454 * Return the quickfix/location list number with the given identifier.
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4455 * Returns -1 if list is not found.
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4456 */
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4457 static int
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4458 qf_id2nr(qf_info_T *qi, int_u qfid)
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4459 {
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4460 int qf_idx;
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4461
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4462 for (qf_idx = 0; qf_idx < qi->qf_listcount; qf_idx++)
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4463 if (qi->qf_lists[qf_idx].qf_id == qfid)
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4464 return qf_idx;
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4465 return INVALID_QFIDX;
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4466 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4467
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4468 /*
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4469 * If the current list is not "save_qfid" and we can find the list with that ID
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4470 * then make it the current list.
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4471 * This is used when autocommands may have changed the current list.
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4472 * Returns OK if successfully restored the list. Returns FAIL if the list with
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4473 * the specified identifier (save_qfid) is not found in the stack.
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4474 */
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4475 static int
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4476 qf_restore_list(qf_info_T *qi, int_u save_qfid)
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4477 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4478 int curlist;
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4479
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4480 if (qi->qf_lists[qi->qf_curlist].qf_id != save_qfid)
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4481 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4482 curlist = qf_id2nr(qi, save_qfid);
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4483 if (curlist < 0)
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4484 // list is not present
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4485 return FAIL;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4486 qi->qf_curlist = curlist;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4487 }
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4488 return OK;
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4489 }
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4490
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4491 /*
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4492 * Jump to the first entry if there is one.
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4493 */
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4494 static void
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4495 qf_jump_first(qf_info_T *qi, int_u save_qfid, int forceit)
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4496 {
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4497 if (qf_restore_list(qi, save_qfid) == FAIL)
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4498 return;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4499
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4500 // Autocommands might have cleared the list, check for that.
14491
9df0fcbfebb2 patch 8.1.0259: no test for fixed quickfix issue
Christian Brabandt <cb@256bit.org>
parents: 14477
diff changeset
4501 if (!qf_list_empty(qi, qi->qf_curlist))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4502 qf_jump(qi, 0, 0, forceit);
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4503 }
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4504
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4505 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4506 * Return TRUE when using ":vimgrep" for ":grep".
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4507 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4508 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4509 grep_internal(cmdidx_T cmdidx)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4510 {
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4511 return ((cmdidx == CMD_grep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4512 || cmdidx == CMD_lgrep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4513 || cmdidx == CMD_grepadd
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4514 || cmdidx == CMD_lgrepadd)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4515 && STRCMP("internal",
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4516 *curbuf->b_p_gp == NUL ? p_gp : curbuf->b_p_gp) == 0);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4517 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4518
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4519 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4520 * Return the make/grep autocmd name.
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4521 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4522 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4523 make_get_auname(cmdidx_T cmdidx)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4524 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4525 switch (cmdidx)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4526 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4527 case CMD_make: return (char_u *)"make";
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4528 case CMD_lmake: return (char_u *)"lmake";
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4529 case CMD_grep: return (char_u *)"grep";
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4530 case CMD_lgrep: return (char_u *)"lgrep";
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4531 case CMD_grepadd: return (char_u *)"grepadd";
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4532 case CMD_lgrepadd: return (char_u *)"lgrepadd";
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4533 default: return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4534 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4535 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4536
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4537 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4538 * Return the name for the errorfile, in allocated memory.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4539 * Find a new unique name when 'makeef' contains "##".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4540 * Returns NULL for error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4541 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4542 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4543 get_mef_name(void)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4544 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4545 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4546 char_u *name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4547 static int start = -1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4548 static int off = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4549 #ifdef HAVE_LSTAT
9387
f094d4085014 commit https://github.com/vim/vim/commit/8767f52fbfd4f053ce00a978227c95f1d7d323fe
Christian Brabandt <cb@256bit.org>
parents: 9379
diff changeset
4550 stat_T sb;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4551 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4552
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4553 if (*p_mef == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4554 {
6721
7347229a646a updated for version 7.4.684
Bram Moolenaar <bram@vim.org>
parents: 6450
diff changeset
4555 name = vim_tempname('e', FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4556 if (name == NULL)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4557 emsg(_(e_notmp));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4558 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4559 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4560
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4561 for (p = p_mef; *p; ++p)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4562 if (p[0] == '#' && p[1] == '#')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4563 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4564
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4565 if (*p == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4566 return vim_strsave(p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4567
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4568 // Keep trying until the name doesn't exist yet.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4569 for (;;)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4570 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4571 if (start == -1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4572 start = mch_get_pid();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4573 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4574 off += 19;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4575
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4576 name = alloc((unsigned)STRLEN(p_mef) + 30);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4577 if (name == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4578 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4579 STRCPY(name, p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4580 sprintf((char *)name + (p - p_mef), "%d%d", start, off);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4581 STRCAT(name, p + 2);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4582 if (mch_getperm(name) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4583 #ifdef HAVE_LSTAT
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4584 // Don't accept a symbolic link, it's a security risk.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4585 && mch_lstat((char *)name, &sb) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4586 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4587 )
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4588 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4589 vim_free(name);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4590 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4591 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4592 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4593
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4594 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4595 * Form the complete command line to invoke 'make'/'grep'. Quote the command
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4596 * using 'shellquote' and append 'shellpipe'. Echo the fully formed command.
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4597 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4598 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4599 make_get_fullcmd(char_u *makecmd, char_u *fname)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4600 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4601 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4602 unsigned len;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4603
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4604 len = (unsigned)STRLEN(p_shq) * 2 + (unsigned)STRLEN(makecmd) + 1;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4605 if (*p_sp != NUL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4606 len += (unsigned)STRLEN(p_sp) + (unsigned)STRLEN(fname) + 3;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4607 cmd = alloc(len);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4608 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4609 return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4610 sprintf((char *)cmd, "%s%s%s", (char *)p_shq, (char *)makecmd,
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4611 (char *)p_shq);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4612
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4613 // If 'shellpipe' empty: don't redirect to 'errorfile'.
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4614 if (*p_sp != NUL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4615 append_redir(cmd, len, p_sp, fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4616
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4617 // Display the fully formed command. Output a newline if there's something
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4618 // else than the :make command that was typed (in which case the cursor is
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4619 // in column 0).
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4620 if (msg_col == 0)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4621 msg_didout = FALSE;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4622 msg_start();
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
4623 msg_puts(":!");
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4624 msg_outtrans(cmd); // show what we are doing
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4625
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4626 return cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4627 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4628
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4629 /*
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4630 * Used for ":make", ":lmake", ":grep", ":lgrep", ":grepadd", and ":lgrepadd"
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4631 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4632 void
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4633 ex_make(exarg_T *eap)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4634 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4635 char_u *fname;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4636 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4637 char_u *enc = NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4638 win_T *wp = NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4639 qf_info_T *qi = &ql_info;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4640 int res;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4641 char_u *au_name = NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4642 int_u save_qfid;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4643
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4644 // Redirect ":grep" to ":vimgrep" if 'grepprg' is "internal".
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4645 if (grep_internal(eap->cmdidx))
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4646 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4647 ex_vimgrep(eap);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4648 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4649 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4650
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4651 au_name = make_get_auname(eap->cmdidx);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4652 if (au_name != NULL && apply_autocmds(EVENT_QUICKFIXCMDPRE, au_name,
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4653 curbuf->b_fname, TRUE, curbuf))
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4654 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4655 #ifdef FEAT_EVAL
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4656 if (aborting())
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4657 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4658 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4659 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4660 enc = (*curbuf->b_p_menc != NUL) ? curbuf->b_p_menc : p_menc;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4661
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4662 if (is_loclist_cmd(eap->cmdidx))
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4663 wp = curwin;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4664
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4665 autowrite_all();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4666 fname = get_mef_name();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4667 if (fname == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4668 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4669 mch_remove(fname); // in case it's not unique
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4670
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4671 cmd = make_get_fullcmd(eap->arg, fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4672 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4673 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4674
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4675 // let the shell know if we are redirecting output or not
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4676 do_shell(cmd, *p_sp != NUL ? SHELL_DOOUT : 0);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4677
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4678 #ifdef AMIGA
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4679 out_flush();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4680 // read window status report and redraw before message
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4681 (void)char_avail();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4682 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4683
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4684 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4685
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4686 res = qf_init(wp, fname, (eap->cmdidx != CMD_make
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4687 && eap->cmdidx != CMD_lmake) ? p_gefm : p_efm,
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4688 (eap->cmdidx != CMD_grepadd
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4689 && eap->cmdidx != CMD_lgrepadd),
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4690 qf_cmdtitle(*eap->cmdlinep), enc);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4691 if (wp != NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4692 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4693 qi = GET_LOC_LIST(wp);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4694 if (qi == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4695 goto cleanup;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4696 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4697 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4698 qf_list_changed(&qi->qf_lists[qi->qf_curlist]);
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4699
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4700 // Remember the current quickfix list identifier, so that we can
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4701 // check for autocommands changing the current quickfix list.
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4702 save_qfid = qi->qf_lists[qi->qf_curlist].qf_id;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4703 if (au_name != NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4704 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4705 curbuf->b_fname, TRUE, curbuf);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4706 if (res > 0 && !eap->forceit && qflist_valid(wp, save_qfid))
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4707 // display the first error
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4708 qf_jump_first(qi, save_qfid, FALSE);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4709
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4710 cleanup:
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4711 decr_quickfix_busy();
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4712 mch_remove(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4713 vim_free(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4714 vim_free(cmd);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4715 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4716
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4717 /*
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4718 * Returns the number of valid entries in the current quickfix/location list.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4719 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4720 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4721 qf_get_size(exarg_T *eap)
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4722 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4723 qf_info_T *qi = &ql_info;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4724 qf_list_T *qfl;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4725 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4726 int i, sz = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4727 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4728
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4729 if (is_loclist_cmd(eap->cmdidx))
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4730 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4731 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4732 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4733 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4734 return 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4735 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4736
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4737 qfl = &qi->qf_lists[qi->qf_curlist];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4738 for (i = 0, qfp = qfl->qf_start; i < qfl->qf_count && qfp != NULL;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4739 ++i, qfp = qfp->qf_next)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4740 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4741 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4742 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4743 if (eap->cmdidx == CMD_cdo || eap->cmdidx == CMD_ldo)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4744 sz++; // Count all valid entries
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4745 else if (qfp->qf_fnum > 0 && qfp->qf_fnum != prev_fnum)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4746 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4747 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4748 sz++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4749 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4750 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4751 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4752 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4753
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4754 return sz;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4755 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4756
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4757 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4758 * Returns the current index of the quickfix/location list.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4759 * Returns 0 if there is an error.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4760 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4761 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4762 qf_get_cur_idx(exarg_T *eap)
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4763 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4764 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4765
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4766 if (is_loclist_cmd(eap->cmdidx))
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4767 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4768 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4769 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4770 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4771 return 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4772 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4773
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4774 return qi->qf_lists[qi->qf_curlist].qf_index;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4775 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4776
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4777 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4778 * Returns the current index in the quickfix/location list (counting only valid
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4779 * entries). If no valid entries are in the list, then returns 1.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4780 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4781 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4782 qf_get_cur_valid_idx(exarg_T *eap)
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4783 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4784 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4785 qf_list_T *qfl;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4786 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4787 int i, eidx = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4788 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4789
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4790 if (is_loclist_cmd(eap->cmdidx))
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4791 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4792 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4793 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4794 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4795 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4796 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4797
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4798 qfl = &qi->qf_lists[qi->qf_curlist];
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4799 qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4800
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4801 // check if the list has valid errors
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4802 if (qfl->qf_count <= 0 || qfl->qf_nonevalid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4803 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4804
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4805 for (i = 1; i <= qfl->qf_index && qfp!= NULL; i++, qfp = qfp->qf_next)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4806 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4807 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4808 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4809 if (eap->cmdidx == CMD_cfdo || eap->cmdidx == CMD_lfdo)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4810 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4811 if (qfp->qf_fnum > 0 && qfp->qf_fnum != prev_fnum)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4812 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4813 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4814 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4815 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4816 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4817 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4818 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4819 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4820 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4821 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4822
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4823 return eidx ? eidx : 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4824 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4825
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4826 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4827 * Get the 'n'th valid error entry in the quickfix or location list.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4828 * Used by :cdo, :ldo, :cfdo and :lfdo commands.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4829 * For :cdo and :ldo returns the 'n'th valid error entry.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4830 * For :cfdo and :lfdo returns the 'n'th valid file entry.
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4831 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4832 static int
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
4833 qf_get_nth_valid_entry(qf_list_T *qfl, int n, int fdo)
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
4834 {
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4835 qfline_T *qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4836 int i, eidx;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4837 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4838
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4839 // check if the list has valid errors
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4840 if (qfl->qf_count <= 0 || qfl->qf_nonevalid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4841 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4842
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4843 for (i = 1, eidx = 0; i <= qfl->qf_count && qfp != NULL;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4844 i++, qfp = qfp->qf_next)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4845 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4846 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4847 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4848 if (fdo)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4849 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4850 if (qfp->qf_fnum > 0 && qfp->qf_fnum != prev_fnum)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4851 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4852 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4853 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4854 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4855 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4856 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4857 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4858 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4859 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4860
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4861 if (eidx == n)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4862 break;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4863 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4864
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4865 if (i <= qfl->qf_count)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4866 return i;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4867 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4868 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4869 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4870
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4871 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4872 * ":cc", ":crewind", ":cfirst" and ":clast".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4873 * ":ll", ":lrewind", ":lfirst" and ":llast".
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4874 * ":cdo", ":ldo", ":cfdo" and ":lfdo"
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4875 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4876 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4877 ex_cc(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4878 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4879 qf_info_T *qi = &ql_info;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4880 int errornr;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4881
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4882 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4883 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4884 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4885 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4886 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4887 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4888 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4889 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4890 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4891
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4892 if (eap->addr_count > 0)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4893 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4894 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4895 {
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4896 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4897 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4898 case CMD_cc: case CMD_ll:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4899 errornr = 0;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4900 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4901 case CMD_crewind: case CMD_lrewind: case CMD_cfirst:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4902 case CMD_lfirst:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4903 errornr = 1;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4904 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4905 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4906 errornr = 32767;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4907 }
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4908 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4909
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4910 // For cdo and ldo commands, jump to the nth valid error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4911 // For cfdo and lfdo commands, jump to the nth valid file entry.
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
4912 if (eap->cmdidx == CMD_cdo || eap->cmdidx == CMD_ldo
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
4913 || eap->cmdidx == CMD_cfdo || eap->cmdidx == CMD_lfdo)
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
4914 errornr = qf_get_nth_valid_entry(&qi->qf_lists[qi->qf_curlist],
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4915 eap->addr_count > 0 ? (int)eap->line1 : 1,
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4916 eap->cmdidx == CMD_cfdo || eap->cmdidx == CMD_lfdo);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4917
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4918 qf_jump(qi, 0, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4919 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4920
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4921 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4922 * ":cnext", ":cnfile", ":cNext" and ":cprevious".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4923 * ":lnext", ":lNext", ":lprevious", ":lnfile", ":lNfile" and ":lpfile".
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4924 * Also, used by ":cdo", ":ldo", ":cfdo" and ":lfdo" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4925 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4926 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4927 ex_cnext(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4928 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4929 qf_info_T *qi = &ql_info;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4930 int errornr;
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4931 int dir;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4932
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4933 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4934 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4935 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4936 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4937 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4938 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4939 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4940 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4941 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4942
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
4943 if (eap->addr_count > 0
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
4944 && (eap->cmdidx != CMD_cdo && eap->cmdidx != CMD_ldo
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
4945 && eap->cmdidx != CMD_cfdo && eap->cmdidx != CMD_lfdo))
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4946 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4947 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4948 errornr = 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4949
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4950 // Depending on the command jump to either next or previous entry/file.
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4951 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4952 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4953 case CMD_cnext: case CMD_lnext: case CMD_cdo: case CMD_ldo:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4954 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4955 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4956 case CMD_cprevious: case CMD_lprevious: case CMD_cNext:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4957 case CMD_lNext:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4958 dir = BACKWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4959 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4960 case CMD_cnfile: case CMD_lnfile: case CMD_cfdo: case CMD_lfdo:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4961 dir = FORWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4962 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4963 case CMD_cpfile: case CMD_lpfile: case CMD_cNfile: case CMD_lNfile:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4964 dir = BACKWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4965 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4966 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4967 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4968 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4969 }
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4970
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4971 qf_jump(qi, dir, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4972 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4973
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4974 /*
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
4975 * ":cfile"/":cgetfile"/":caddfile" commands.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4976 * ":lfile"/":lgetfile"/":laddfile" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4977 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4978 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4979 ex_cfile(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4980 {
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
4981 char_u *enc = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4982 win_T *wp = NULL;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4983 qf_info_T *qi = &ql_info;
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4984 char_u *au_name = NULL;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4985 int_u save_qfid = 0; // init for gcc
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
4986 int res;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4987
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4988 switch (eap->cmdidx)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4989 {
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4990 case CMD_cfile: au_name = (char_u *)"cfile"; break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4991 case CMD_cgetfile: au_name = (char_u *)"cgetfile"; break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4992 case CMD_caddfile: au_name = (char_u *)"caddfile"; break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4993 case CMD_lfile: au_name = (char_u *)"lfile"; break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4994 case CMD_lgetfile: au_name = (char_u *)"lgetfile"; break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4995 case CMD_laddfile: au_name = (char_u *)"laddfile"; break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4996 default: break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4997 }
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4998 if (au_name != NULL)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4999 apply_autocmds(EVENT_QUICKFIXCMDPRE, au_name, NULL, FALSE, curbuf);
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
5000 enc = (*curbuf->b_p_menc != NUL) ? curbuf->b_p_menc : p_menc;
2296
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5001 #ifdef FEAT_BROWSE
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5002 if (cmdmod.browse)
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5003 {
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5004 char_u *browse_file = do_browse(0, (char_u *)_("Error file"), eap->arg,
13802
378f9f8e6d8f patch 8.0.1773: dialog messages are not translated
Christian Brabandt <cb@256bit.org>
parents: 13800
diff changeset
5005 NULL, NULL,
378f9f8e6d8f patch 8.0.1773: dialog messages are not translated
Christian Brabandt <cb@256bit.org>
parents: 13800
diff changeset
5006 (char_u *)_(BROWSE_FILTER_ALL_FILES), NULL);
2296
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5007 if (browse_file == NULL)
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5008 return;
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5009 set_string_option_direct((char_u *)"ef", -1, browse_file, OPT_FREE, 0);
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5010 vim_free(browse_file);
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5011 }
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5012 else
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5013 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5014 if (*eap->arg != NUL)
694
07d199fe02ed updated for version 7.0209
vimboss
parents: 682
diff changeset
5015 set_string_option_direct((char_u *)"ef", -1, eap->arg, OPT_FREE, 0);
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
5016
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5017 if (is_loclist_cmd(eap->cmdidx))
13078
a1f8939a4644 patch 8.0.1414: accessing freed memory in :lfile.
Christian Brabandt <cb@256bit.org>
parents: 13076
diff changeset
5018 wp = curwin;
a1f8939a4644 patch 8.0.1414: accessing freed memory in :lfile.
Christian Brabandt <cb@256bit.org>
parents: 13076
diff changeset
5019
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5020 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5021
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5022 // This function is used by the :cfile, :cgetfile and :caddfile
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5023 // commands.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5024 // :cfile always creates a new quickfix list and jumps to the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5025 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5026 // :cgetfile creates a new quickfix list but doesn't jump to the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5027 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5028 // :caddfile adds to an existing quickfix list. If there is no
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5029 // quickfix list then a new list is created.
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
5030 res = qf_init(wp, p_ef, p_efm, (eap->cmdidx != CMD_caddfile
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
5031 && eap->cmdidx != CMD_laddfile),
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
5032 qf_cmdtitle(*eap->cmdlinep), enc);
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5033 if (wp != NULL)
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5034 {
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5035 qi = GET_LOC_LIST(wp);
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5036 if (qi == NULL)
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5037 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5038 decr_quickfix_busy();
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5039 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5040 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5041 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5042 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5043 qf_list_changed(&qi->qf_lists[qi->qf_curlist]);
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5044 save_qfid = qi->qf_lists[qi->qf_curlist].qf_id;
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
5045 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
5046 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name, NULL, FALSE, curbuf);
13252
66b8b29854d9 patch 8.0.1500: possible NULL pointer dereference
Christian Brabandt <cb@256bit.org>
parents: 13244
diff changeset
5047
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5048 // Jump to the first error for a new list and if autocmds didn't
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5049 // free the list.
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5050 if (res > 0 && (eap->cmdidx == CMD_cfile || eap->cmdidx == CMD_lfile)
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5051 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5052 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5053 qf_jump_first(qi, save_qfid, eap->forceit);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5054
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5055 decr_quickfix_busy();
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5056 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5057
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5058 /*
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5059 * Return the vimgrep autocmd name.
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5060 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5061 static char_u *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5062 vgr_get_auname(cmdidx_T cmdidx)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5063 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5064 switch (cmdidx)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5065 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5066 case CMD_vimgrep: return (char_u *)"vimgrep";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5067 case CMD_lvimgrep: return (char_u *)"lvimgrep";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5068 case CMD_vimgrepadd: return (char_u *)"vimgrepadd";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5069 case CMD_lvimgrepadd: return (char_u *)"lvimgrepadd";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5070 case CMD_grep: return (char_u *)"grep";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5071 case CMD_lgrep: return (char_u *)"lgrep";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5072 case CMD_grepadd: return (char_u *)"grepadd";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5073 case CMD_lgrepadd: return (char_u *)"lgrepadd";
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5074 default: return NULL;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5075 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5076 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5077
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5078 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5079 * Initialize the regmatch used by vimgrep for pattern "s".
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5080 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5081 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5082 vgr_init_regmatch(regmmatch_T *regmatch, char_u *s)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5083 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5084 // Get the search pattern: either white-separated or enclosed in //
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5085 regmatch->regprog = NULL;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5086
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5087 if (s == NULL || *s == NUL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5088 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5089 // Pattern is empty, use last search pattern.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5090 if (last_search_pat() == NULL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5091 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5092 emsg(_(e_noprevre));
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5093 return;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5094 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5095 regmatch->regprog = vim_regcomp(last_search_pat(), RE_MAGIC);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5096 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5097 else
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5098 regmatch->regprog = vim_regcomp(s, RE_MAGIC);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5099
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5100 regmatch->rmm_ic = p_ic;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5101 regmatch->rmm_maxcol = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5102 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5103
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5104 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5105 * Display a file name when vimgrep is running.
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5106 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5107 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5108 vgr_display_fname(char_u *fname)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5109 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5110 char_u *p;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5111
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5112 msg_start();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5113 p = msg_strtrunc(fname, TRUE);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5114 if (p == NULL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5115 msg_outtrans(fname);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5116 else
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5117 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5118 msg_outtrans(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5119 vim_free(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5120 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5121 msg_clr_eos();
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5122 msg_didout = FALSE; // overwrite this message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5123 msg_nowait = TRUE; // don't wait for this message
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5124 msg_col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5125 out_flush();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5126 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5127
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5128 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5129 * Load a dummy buffer to search for a pattern using vimgrep.
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5130 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5131 static buf_T *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5132 vgr_load_dummy_buf(
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5133 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5134 char_u *dirname_start,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5135 char_u *dirname_now)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5136 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5137 int save_mls;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5138 #if defined(FEAT_SYN_HL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5139 char_u *save_ei = NULL;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5140 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5141 buf_T *buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5142
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5143 #if defined(FEAT_SYN_HL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5144 // Don't do Filetype autocommands to avoid loading syntax and
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5145 // indent scripts, a great speed improvement.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5146 save_ei = au_event_disable(",Filetype");
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5147 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5148 // Don't use modelines here, it's useless.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5149 save_mls = p_mls;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5150 p_mls = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5151
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5152 // Load file into a buffer, so that 'fileencoding' is detected,
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5153 // autocommands applied, etc.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5154 buf = load_dummy_buffer(fname, dirname_start, dirname_now);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5155
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5156 p_mls = save_mls;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5157 #if defined(FEAT_SYN_HL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5158 au_event_restore(save_ei);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5159 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5160
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5161 return buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5162 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5163
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5164 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5165 * Check whether a quickfix/location list valid. Autocmds may remove or change
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5166 * a quickfix list when vimgrep is running. If the list is not found, create a
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5167 * new list.
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5168 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5169 static int
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5170 vgr_qflist_valid(
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5171 win_T *wp,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5172 qf_info_T *qi,
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5173 int_u qfid,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5174 char_u *title)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5175 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5176 // Verify that the quickfix/location list was not freed by an autocmd
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5177 if (!qflist_valid(wp, qfid))
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5178 {
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5179 if (wp != NULL)
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5180 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5181 // An autocmd has freed the location list.
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5182 emsg(_(e_loc_list_changed));
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5183 return FALSE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5184 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5185 else
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5186 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5187 // Quickfix list is not found, create a new one.
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5188 qf_new_list(qi, title);
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5189 return TRUE;
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5190 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5191 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5192
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
5193 if (qf_restore_list(qi, qfid) == FAIL)
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
5194 return FALSE;
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5195
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5196 return TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5197 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5198
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5199 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5200 * Search for a pattern in all the lines in a buffer and add the matching lines
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5201 * to a quickfix list.
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5202 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5203 static int
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5204 vgr_match_buflines(
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5205 qf_info_T *qi,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5206 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5207 buf_T *buf,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5208 regmmatch_T *regmatch,
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5209 long *tomatch,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5210 int duplicate_name,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5211 int flags)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5212 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5213 int found_match = FALSE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5214 long lnum;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5215 colnr_T col;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5216
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5217 for (lnum = 1; lnum <= buf->b_ml.ml_line_count && *tomatch > 0; ++lnum)
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5218 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5219 col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5220 while (vim_regexec_multi(regmatch, curwin, buf, lnum,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5221 col, NULL, NULL) > 0)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5222 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5223 // Pass the buffer number so that it gets used even for a
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5224 // dummy buffer, unless duplicate_name is set, then the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5225 // buffer will be wiped out below.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5226 if (qf_add_entry(qi,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5227 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5228 NULL, // dir
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5229 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
5230 NULL,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5231 duplicate_name ? 0 : buf->b_fnum,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5232 ml_get_buf(buf,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5233 regmatch->startpos[0].lnum + lnum, FALSE),
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5234 regmatch->startpos[0].lnum + lnum,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5235 regmatch->startpos[0].col + 1,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5236 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5237 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5238 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5239 0, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5240 TRUE // valid
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5241 ) == FAIL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5242 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5243 got_int = TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5244 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5245 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5246 found_match = TRUE;
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5247 if (--*tomatch == 0)
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5248 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5249 if ((flags & VGR_GLOBAL) == 0
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5250 || regmatch->endpos[0].lnum > 0)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5251 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5252 col = regmatch->endpos[0].col
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5253 + (col == regmatch->endpos[0].col);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5254 if (col > (colnr_T)STRLEN(ml_get_buf(buf, lnum, FALSE)))
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5255 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5256 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5257 line_breakcheck();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5258 if (got_int)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5259 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5260 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5261
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5262 return found_match;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5263 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5264
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5265 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5266 * Jump to the first match and update the directory.
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5267 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5268 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5269 vgr_jump_to_match(
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5270 qf_info_T *qi,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5271 int forceit,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5272 int *redraw_for_dummy,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5273 buf_T *first_match_buf,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5274 char_u *target_dir)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5275 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5276 buf_T *buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5277
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5278 buf = curbuf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5279 qf_jump(qi, 0, 0, forceit);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5280 if (buf != curbuf)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5281 // If we jumped to another buffer redrawing will already be
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5282 // taken care of.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5283 *redraw_for_dummy = FALSE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5284
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5285 // Jump to the directory used after loading the buffer.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5286 if (curbuf == first_match_buf && target_dir != NULL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5287 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5288 exarg_T ea;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5289
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5290 ea.arg = target_dir;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5291 ea.cmdidx = CMD_lcd;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5292 ex_cd(&ea);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5293 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5294 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5295
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5296 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5297 * ":vimgrep {pattern} file(s)"
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5298 * ":vimgrepadd {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5299 * ":lvimgrep {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5300 * ":lvimgrepadd {pattern} file(s)"
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5301 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5302 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5303 ex_vimgrep(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5304 {
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5305 regmmatch_T regmatch;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5306 int fcount;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5307 char_u **fnames;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5308 char_u *fname;
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5309 char_u *title;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5310 char_u *s;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5311 char_u *p;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5312 int fi;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5313 qf_info_T *qi = &ql_info;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5314 qf_list_T *qfl;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5315 int_u save_qfid;
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5316 win_T *wp = NULL;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5317 buf_T *buf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5318 int duplicate_name = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5319 int using_dummy;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5320 int redraw_for_dummy = FALSE;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5321 int found_match;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5322 buf_T *first_match_buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5323 time_t seconds = 0;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5324 aco_save_T aco;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5325 int flags = 0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5326 long tomatch;
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5327 char_u *dirname_start = NULL;
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5328 char_u *dirname_now = NULL;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5329 char_u *target_dir = NULL;
1683
75dbeedddaa9 updated for version 7.2b-016
vimboss
parents: 1672
diff changeset
5330 char_u *au_name = NULL;
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5331
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5332 au_name = vgr_get_auname(eap->cmdidx);
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
5333 if (au_name != NULL && apply_autocmds(EVENT_QUICKFIXCMDPRE, au_name,
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
5334 curbuf->b_fname, TRUE, curbuf))
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5335 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5336 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
5337 if (aborting())
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5338 return;
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5339 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5340 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5341
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5342 if (is_loclist_cmd(eap->cmdidx))
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5343 {
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5344 qi = ll_get_or_alloc_list(curwin);
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5345 if (qi == NULL)
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5346 return;
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5347 wp = curwin;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5348 }
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5349
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5350 if (eap->addr_count > 0)
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5351 tomatch = eap->line2;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5352 else
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5353 tomatch = MAXLNUM;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5354
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5355 // Get the search pattern: either white-separated or enclosed in //
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5356 regmatch.regprog = NULL;
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
5357 title = vim_strsave(qf_cmdtitle(*eap->cmdlinep));
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5358 p = skip_vimgrep_pat(eap->arg, &s, &flags);
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5359 if (p == NULL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5360 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5361 emsg(_(e_invalpat));
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5362 goto theend;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5363 }
4197
07fef68eb018 updated for version 7.3.850
Bram Moolenaar <bram@vim.org>
parents: 4003
diff changeset
5364
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5365 vgr_init_regmatch(&regmatch, s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5366 if (regmatch.regprog == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5367 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5368
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5369 p = skipwhite(p);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5370 if (*p == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5371 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5372 emsg(_("E683: File name missing or invalid pattern"));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5373 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5374 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5375
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
5376 if ((eap->cmdidx != CMD_grepadd && eap->cmdidx != CMD_lgrepadd
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5377 && eap->cmdidx != CMD_vimgrepadd
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5378 && eap->cmdidx != CMD_lvimgrepadd)
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
5379 || qf_stack_empty(qi))
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5380 // make place for a new list
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
5381 qf_new_list(qi, title != NULL ? title : qf_cmdtitle(*eap->cmdlinep));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5382
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5383 // parse the list of arguments
3620
4f1c511e71f8 updated for version 7.3.570
Bram Moolenaar <bram@vim.org>
parents: 3555
diff changeset
5384 if (get_arglist_exp(p, &fcount, &fnames, TRUE) == FAIL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5385 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5386 if (fcount == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5387 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5388 emsg(_(e_nomatch));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5389 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5390 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5391
7558
9a4c9dccd603 commit https://github.com/vim/vim/commit/b86a343280b08d6701da68ee0651e960a0a7a61c
Christian Brabandt <cb@256bit.org>
parents: 7515
diff changeset
5392 dirname_start = alloc_id(MAXPATHL, aid_qf_dirname_start);
9a4c9dccd603 commit https://github.com/vim/vim/commit/b86a343280b08d6701da68ee0651e960a0a7a61c
Christian Brabandt <cb@256bit.org>
parents: 7515
diff changeset
5393 dirname_now = alloc_id(MAXPATHL, aid_qf_dirname_now);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5394 if (dirname_start == NULL || dirname_now == NULL)
7662
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5395 {
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5396 FreeWild(fcount, fnames);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5397 goto theend;
7662
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5398 }
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5399
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5400 // Remember the current directory, because a BufRead autocommand that does
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5401 // ":lcd %:p:h" changes the meaning of short path names.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5402 mch_dirname(dirname_start, MAXPATHL);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5403
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5404 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5405
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5406 // Remember the current quickfix list identifier, so that we can check for
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5407 // autocommands changing the current quickfix list.
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5408 save_qfid = qi->qf_lists[qi->qf_curlist].qf_id;
4003
706c87d16d40 updated for version 7.3.756
Bram Moolenaar <bram@vim.org>
parents: 3982
diff changeset
5409
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5410 seconds = (time_t)0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5411 for (fi = 0; fi < fcount && !got_int && tomatch > 0; ++fi)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5412 {
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5413 fname = shorten_fname1(fnames[fi]);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5414 if (time(NULL) > seconds)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5415 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5416 // Display the file name every second or so, show the user we are
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5417 // working on it.
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5418 seconds = time(NULL);
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5419 vgr_display_fname(fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5420 }
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5421
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5422 buf = buflist_findname_exp(fnames[fi]);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5423 if (buf == NULL || buf->b_ml.ml_mfp == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5424 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5425 // Remember that a buffer with this name already exists.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5426 duplicate_name = (buf != NULL);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5427 using_dummy = TRUE;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5428 redraw_for_dummy = TRUE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5429
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5430 buf = vgr_load_dummy_buf(fname, dirname_start, dirname_now);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5431 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5432 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5433 // Use existing, loaded buffer.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5434 using_dummy = FALSE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5435
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5436 // Check whether the quickfix list is still valid. When loading a
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5437 // buffer above, autocommands might have changed the quickfix list.
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
5438 if (!vgr_qflist_valid(wp, qi, save_qfid, qf_cmdtitle(*eap->cmdlinep)))
13660
2d94fcb0277d patch 8.0.1702: leaking memory when autocommands make quickfix list invalid
Christian Brabandt <cb@256bit.org>
parents: 13612
diff changeset
5439 {
2d94fcb0277d patch 8.0.1702: leaking memory when autocommands make quickfix list invalid
Christian Brabandt <cb@256bit.org>
parents: 13612
diff changeset
5440 FreeWild(fcount, fnames);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5441 decr_quickfix_busy();
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5442 goto theend;
13660
2d94fcb0277d patch 8.0.1702: leaking memory when autocommands make quickfix list invalid
Christian Brabandt <cb@256bit.org>
parents: 13612
diff changeset
5443 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5444 save_qfid = qi->qf_lists[qi->qf_curlist].qf_id;
4003
706c87d16d40 updated for version 7.3.756
Bram Moolenaar <bram@vim.org>
parents: 3982
diff changeset
5445
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5446 if (buf == NULL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5447 {
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5448 if (!got_int)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5449 smsg(_("Cannot open file \"%s\""), fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5450 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5451 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5452 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5453 // Try for a match in all lines of the buffer.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5454 // For ":1vimgrep" look for first match only.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5455 found_match = vgr_match_buflines(qi, fname, buf, &regmatch,
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5456 &tomatch, duplicate_name, flags);
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5457
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5458 if (using_dummy)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5459 {
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5460 if (found_match && first_match_buf == NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5461 first_match_buf = buf;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5462 if (duplicate_name)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5463 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5464 // Never keep a dummy buffer if there is another buffer
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5465 // with the same name.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5466 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5467 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5468 }
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5469 else if (!cmdmod.hide
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5470 || buf->b_p_bh[0] == 'u' // "unload"
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5471 || buf->b_p_bh[0] == 'w' // "wipe"
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5472 || buf->b_p_bh[0] == 'd') // "delete"
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5473 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5474 // When no match was found we don't need to remember the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5475 // buffer, wipe it out. If there was a match and it
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5476 // wasn't the first one or we won't jump there: only
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5477 // unload the buffer.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5478 // Ignore 'hidden' here, because it may lead to having too
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5479 // many swap files.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5480 if (!found_match)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5481 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5482 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5483 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5484 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5485 else if (buf != first_match_buf || (flags & VGR_NOJUMP))
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5486 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5487 unload_dummy_buffer(buf, dirname_start);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5488 // Keeping the buffer, remove the dummy flag.
9540
64a791c53418 commit https://github.com/vim/vim/commit/015102e91e978a0bb42a14461c132a85e8f7e1ea
Christian Brabandt <cb@256bit.org>
parents: 9538
diff changeset
5489 buf->b_flags &= ~BF_DUMMY;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5490 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5491 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5492 }
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5493
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5494 if (buf != NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5495 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5496 // Keeping the buffer, remove the dummy flag.
9540
64a791c53418 commit https://github.com/vim/vim/commit/015102e91e978a0bb42a14461c132a85e8f7e1ea
Christian Brabandt <cb@256bit.org>
parents: 9538
diff changeset
5497 buf->b_flags &= ~BF_DUMMY;
64a791c53418 commit https://github.com/vim/vim/commit/015102e91e978a0bb42a14461c132a85e8f7e1ea
Christian Brabandt <cb@256bit.org>
parents: 9538
diff changeset
5498
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5499 // If the buffer is still loaded we need to use the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5500 // directory we jumped to below.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5501 if (buf == first_match_buf
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5502 && target_dir == NULL
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5503 && STRCMP(dirname_start, dirname_now) != 0)
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5504 target_dir = vim_strsave(dirname_now);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5505
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5506 // The buffer is still loaded, the Filetype autocommands
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5507 // need to be done now, in that buffer. And the modelines
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5508 // need to be done (again). But not the window-local
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5509 // options!
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5510 aucmd_prepbuf(&aco, buf);
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5511 #if defined(FEAT_SYN_HL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5512 apply_autocmds(EVENT_FILETYPE, buf->b_p_ft,
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5513 buf->b_fname, TRUE, buf);
677
e649c78407e6 updated for version 7.0202
vimboss
parents: 665
diff changeset
5514 #endif
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5515 do_modelines(OPT_NOWIN);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5516 aucmd_restbuf(&aco);
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5517 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5518 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5519 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5520 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5521
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5522 FreeWild(fcount, fnames);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5523
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5524 qfl = &qi->qf_lists[qi->qf_curlist];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5525 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5526 qfl->qf_ptr = qfl->qf_start;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5527 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5528 qf_list_changed(qfl);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5529
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
5530 qf_update_buffer(qi, NULL);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5531
842
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5532 if (au_name != NULL)
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5533 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5534 curbuf->b_fname, TRUE, curbuf);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5535 // The QuickFixCmdPost autocmd may free the quickfix list. Check the list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5536 // is still valid.
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5537 if (!qflist_valid(wp, save_qfid)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5538 || qf_restore_list(qi, save_qfid) == FAIL)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5539 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5540 decr_quickfix_busy();
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5541 goto theend;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5542 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5543
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
5544 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5545 if (!qf_list_empty(qi, qi->qf_curlist))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5546 {
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5547 if ((flags & VGR_NOJUMP) == 0)
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5548 vgr_jump_to_match(qi, eap->forceit, &redraw_for_dummy,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5549 first_match_buf, target_dir);
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5550 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5551 else
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5552 semsg(_(e_nomatch2), s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5553
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5554 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5555
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5556 // If we loaded a dummy buffer into the current window, the autocommands
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5557 // may have messed up things, need to redraw and recompute folds.
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5558 if (redraw_for_dummy)
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5559 {
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5560 #ifdef FEAT_FOLDING
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5561 foldUpdateAll(curwin);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5562 #else
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5563 redraw_later(NOT_VALID);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5564 #endif
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5565 }
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5566
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5567 theend:
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5568 vim_free(title);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5569 vim_free(dirname_now);
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5570 vim_free(dirname_start);
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5571 vim_free(target_dir);
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
5572 vim_regfree(regmatch.regprog);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5573 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5574
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5575 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5576 * Restore current working directory to "dirname_start" if they differ, taking
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5577 * into account whether it is set locally or globally.
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5578 */
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5579 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5580 restore_start_dir(char_u *dirname_start)
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5581 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5582 char_u *dirname_now = alloc(MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5583
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5584 if (NULL != dirname_now)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5585 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5586 mch_dirname(dirname_now, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5587 if (STRCMP(dirname_start, dirname_now) != 0)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5588 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5589 // If the directory has changed, change it back by building up an
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5590 // appropriate ex command and executing it.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5591 exarg_T ea;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5592
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5593 ea.arg = dirname_start;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5594 ea.cmdidx = (curwin->w_localdir == NULL) ? CMD_cd : CMD_lcd;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5595 ex_cd(&ea);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5596 }
3974
4d1753f3e85c updated for version 7.3.742
Bram Moolenaar <bram@vim.org>
parents: 3965
diff changeset
5597 vim_free(dirname_now);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5598 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5599 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5600
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5601 /*
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5602 * Load file "fname" into a dummy buffer and return the buffer pointer,
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5603 * placing the directory resulting from the buffer load into the
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5604 * "resulting_dir" pointer. "resulting_dir" must be allocated by the caller
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5605 * prior to calling this function. Restores directory to "dirname_start" prior
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5606 * to returning, if autocmds or the 'autochdir' option have changed it.
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5607 *
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5608 * If creating the dummy buffer does not fail, must call unload_dummy_buffer()
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5609 * or wipe_dummy_buffer() later!
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5610 *
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5611 * Returns NULL if it fails.
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5612 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5613 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5614 load_dummy_buffer(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5615 char_u *fname,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5616 char_u *dirname_start, // in: old directory
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5617 char_u *resulting_dir) // out: new directory
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5618 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5619 buf_T *newbuf;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5620 bufref_T newbufref;
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5621 bufref_T newbuf_to_wipe;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5622 int failed = TRUE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5623 aco_save_T aco;
13056
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5624 int readfile_result;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5625
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5626 // Allocate a buffer without putting it in the buffer list.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5627 newbuf = buflist_new(NULL, NULL, (linenr_T)1, BLN_DUMMY);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5628 if (newbuf == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5629 return NULL;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5630 set_bufref(&newbufref, newbuf);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5631
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5632 // Init the options.
177
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5633 buf_copy_options(newbuf, BCO_ENTER | BCO_NOHELP);
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5634
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5635 // need to open the memfile before putting the buffer in a window
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5636 if (ml_open(newbuf) == OK)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5637 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5638 // Make sure this buffer isn't wiped out by autocommands.
13056
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5639 ++newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5640
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5641 // set curwin/curbuf to buf and save a few things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5642 aucmd_prepbuf(&aco, newbuf);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5643
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5644 // Need to set the filename for autocommands.
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5645 (void)setfname(curbuf, fname, NULL, FALSE);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5646
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5647 // Create swap file now to avoid the ATTENTION message.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5648 check_need_swap(TRUE);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5649
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5650 // Remove the "dummy" flag, otherwise autocommands may not
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5651 // work.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5652 curbuf->b_flags &= ~BF_DUMMY;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5653
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5654 newbuf_to_wipe.br_buf = NULL;
13056
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5655 readfile_result = readfile(fname, NULL,
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5656 (linenr_T)0, (linenr_T)0, (linenr_T)MAXLNUM,
13056
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5657 NULL, READ_NEW | READ_DUMMY);
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5658 --newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5659 if (readfile_result == OK
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5660 && !got_int
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5661 && !(curbuf->b_flags & BF_NEW))
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5662 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5663 failed = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5664 if (curbuf != newbuf)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5665 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5666 // Bloody autocommands changed the buffer! Can happen when
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5667 // using netrw and editing a remote file. Use the current
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5668 // buffer instead, delete the dummy one after restoring the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5669 // window stuff.
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5670 set_bufref(&newbuf_to_wipe, newbuf);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5671 newbuf = curbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5672 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5673 }
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5674
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5675 // restore curwin/curbuf and a few other things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5676 aucmd_restbuf(&aco);
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5677 if (newbuf_to_wipe.br_buf != NULL && bufref_valid(&newbuf_to_wipe))
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5678 wipe_buffer(newbuf_to_wipe.br_buf, FALSE);
9485
c16e207dc465 commit https://github.com/vim/vim/commit/ea3f2e7be447a8f0c4436869620f908de5e8ef1e
Christian Brabandt <cb@256bit.org>
parents: 9475
diff changeset
5679
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5680 // Add back the "dummy" flag, otherwise buflist_findname_stat() won't
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5681 // skip it.
9485
c16e207dc465 commit https://github.com/vim/vim/commit/ea3f2e7be447a8f0c4436869620f908de5e8ef1e
Christian Brabandt <cb@256bit.org>
parents: 9475
diff changeset
5682 newbuf->b_flags |= BF_DUMMY;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5683 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5684
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5685 // When autocommands/'autochdir' option changed directory: go back.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5686 // Let the caller know what the resulting dir was first, in case it is
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5687 // important.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5688 mch_dirname(resulting_dir, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5689 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5690
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5691 if (!bufref_valid(&newbufref))
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5692 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5693 if (failed)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5694 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5695 wipe_dummy_buffer(newbuf, dirname_start);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5696 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5697 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5698 return newbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5699 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5700
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5701 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5702 * Wipe out the dummy buffer that load_dummy_buffer() created. Restores
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5703 * directory to "dirname_start" prior to returning, if autocmds or the
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5704 * 'autochdir' option have changed it.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5705 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5706 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5707 wipe_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5708 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5709 if (curbuf != buf) // safety check
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5710 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5711 #if defined(FEAT_EVAL)
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5712 cleanup_T cs;
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5713
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5714 // Reset the error/interrupt/exception state here so that aborting()
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5715 // returns FALSE when wiping out the buffer. Otherwise it doesn't
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5716 // work when got_int is set.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5717 enter_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5718 #endif
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5719
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5720 wipe_buffer(buf, FALSE);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5721
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5722 #if defined(FEAT_EVAL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5723 // Restore the error/interrupt/exception state if not discarded by a
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5724 // new aborting error, interrupt, or uncaught exception.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5725 leave_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5726 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5727 // When autocommands/'autochdir' option changed directory: go back.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5728 restore_start_dir(dirname_start);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5729 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5730 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5731
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5732 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5733 * Unload the dummy buffer that load_dummy_buffer() created. Restores
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5734 * directory to "dirname_start" prior to returning, if autocmds or the
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5735 * 'autochdir' option have changed it.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5736 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5737 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5738 unload_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5739 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5740 if (curbuf != buf) // safety check
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5741 {
3365
9ccdc4a69d8f updated for version 7.3.449
Bram Moolenaar <bram@vim.org>
parents: 3269
diff changeset
5742 close_buffer(NULL, buf, DOBUF_UNLOAD, FALSE);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5743
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5744 // When autocommands/'autochdir' option changed directory: go back.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5745 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5746 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5747 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5748
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5749 #if defined(FEAT_EVAL) || defined(PROTO)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5750 /*
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5751 * Add each quickfix error to list "list" as a dictionary.
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5752 * If qf_idx is -1, use the current list. Otherwise, use the specified list.
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5753 */
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5754 int
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5755 get_errorlist(qf_info_T *qi_arg, win_T *wp, int qf_idx, list_T *list)
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5756 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5757 qf_info_T *qi = qi_arg;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5758 dict_T *dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5759 char_u buf[2];
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5760 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5761 int i;
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5762 int bufnum;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5763
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5764 if (qi == NULL)
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5765 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5766 qi = &ql_info;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5767 if (wp != NULL)
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5768 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5769 qi = GET_LOC_LIST(wp);
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5770 if (qi == NULL)
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5771 return FAIL;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5772 }
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5773 }
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5774
13800
e4dc4ede9ef8 patch 8.0.1772: quickfix: mixup of FALSE and FAIL, returning -1
Christian Brabandt <cb@256bit.org>
parents: 13764
diff changeset
5775 if (qf_idx == INVALID_QFIDX)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5776 qf_idx = qi->qf_curlist;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5777
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5778 if (qf_idx >= qi->qf_listcount || qf_list_empty(qi, qf_idx))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5779 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5780
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5781 qfp = qi->qf_lists[qf_idx].qf_start;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5782 for (i = 1; !got_int && i <= qi->qf_lists[qf_idx].qf_count; ++i)
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5783 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5784 // Handle entries with a non-existing buffer number.
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5785 bufnum = qfp->qf_fnum;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5786 if (bufnum != 0 && (buflist_findnr(bufnum) == NULL))
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5787 bufnum = 0;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5788
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5789 if ((dict = dict_alloc()) == NULL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5790 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5791 if (list_append_dict(list, dict) == FAIL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5792 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5793
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5794 buf[0] = qfp->qf_type;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5795 buf[1] = NUL;
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5796 if ( dict_add_number(dict, "bufnr", (long)bufnum) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5797 || dict_add_number(dict, "lnum", (long)qfp->qf_lnum) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5798 || dict_add_number(dict, "col", (long)qfp->qf_col) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5799 || dict_add_number(dict, "vcol", (long)qfp->qf_viscol) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5800 || dict_add_number(dict, "nr", (long)qfp->qf_nr) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5801 || dict_add_string(dict, "module", qfp->qf_module) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5802 || dict_add_string(dict, "pattern", qfp->qf_pattern) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5803 || dict_add_string(dict, "text", qfp->qf_text) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5804 || dict_add_string(dict, "type", buf) == FAIL
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
5805 || dict_add_number(dict, "valid", (long)qfp->qf_valid) == FAIL)
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5806 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5807
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5808 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5809 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5810 break;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5811 }
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5812 return OK;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5813 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5814
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5815 // Flags used by getqflist()/getloclist() to determine which fields to return.
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5816 enum {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5817 QF_GETLIST_NONE = 0x0,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5818 QF_GETLIST_TITLE = 0x1,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5819 QF_GETLIST_ITEMS = 0x2,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5820 QF_GETLIST_NR = 0x4,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5821 QF_GETLIST_WINID = 0x8,
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
5822 QF_GETLIST_CONTEXT = 0x10,
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5823 QF_GETLIST_ID = 0x20,
12465
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5824 QF_GETLIST_IDX = 0x40,
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5825 QF_GETLIST_SIZE = 0x80,
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5826 QF_GETLIST_TICK = 0x100,
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5827 QF_GETLIST_FILEWINID = 0x200,
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5828 QF_GETLIST_ALL = 0x3FF,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5829 };
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5830
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5831 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5832 * Parse text from 'di' and return the quickfix list items.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5833 * Existing quickfix lists are not modified.
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5834 */
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5835 static int
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5836 qf_get_list_from_lines(dict_T *what, dictitem_T *di, dict_T *retdict)
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5837 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5838 int status = FAIL;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5839 qf_info_T *qi;
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5840 char_u *errorformat = p_efm;
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5841 dictitem_T *efm_di;
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5842 list_T *l;
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5843
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5844 // Only a List value is supported
12303
ec7a4fd21dd5 patch 8.0.1031: "text" argument for getqflist() is confusing
Christian Brabandt <cb@256bit.org>
parents: 12299
diff changeset
5845 if (di->di_tv.v_type == VAR_LIST && di->di_tv.vval.v_list != NULL)
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5846 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5847 // If errorformat is supplied then use it, otherwise use the 'efm'
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5848 // option setting
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5849 if ((efm_di = dict_find(what, (char_u *)"efm", -1)) != NULL)
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5850 {
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5851 if (efm_di->di_tv.v_type != VAR_STRING ||
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5852 efm_di->di_tv.vval.v_string == NULL)
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5853 return FAIL;
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5854 errorformat = efm_di->di_tv.vval.v_string;
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5855 }
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5856
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5857 l = list_alloc();
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5858 if (l == NULL)
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5859 return FAIL;
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5860
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
5861 qi = qf_alloc_stack(QFLT_INTERNAL);
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5862 if (qi != NULL)
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5863 {
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5864 if (qf_init_ext(qi, 0, NULL, NULL, &di->di_tv, errorformat,
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5865 TRUE, (linenr_T)0, (linenr_T)0, NULL, NULL) > 0)
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5866 {
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5867 (void)get_errorlist(qi, NULL, 0, l);
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
5868 qf_free(&qi->qf_lists[0]);
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5869 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5870 free(qi);
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5871 }
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5872 dict_add_list(retdict, "items", l);
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5873 status = OK;
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5874 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5875
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5876 return status;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5877 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5878
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5879 /*
13115
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5880 * Return the quickfix/location list window identifier in the current tabpage.
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5881 */
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5882 static int
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5883 qf_winid(qf_info_T *qi)
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5884 {
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5885 win_T *win;
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5886
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5887 // The quickfix window can be opened even if the quickfix list is not set
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5888 // using ":copen". This is not true for location lists.
13115
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5889 if (qi == NULL)
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5890 return 0;
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5891 win = qf_find_win(qi);
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5892 if (win != NULL)
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5893 return win->w_id;
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5894 return 0;
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5895 }
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5896
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5897 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5898 * Convert the keys in 'what' to quickfix list property flags.
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5899 */
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5900 static int
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5901 qf_getprop_keys2flags(dict_T *what, int loclist)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5902 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5903 int flags = QF_GETLIST_NONE;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5904
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5905 if (dict_find(what, (char_u *)"all", -1) != NULL)
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5906 {
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5907 flags |= QF_GETLIST_ALL;
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5908 if (!loclist)
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5909 // File window ID is applicable only to location list windows
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5910 flags &= ~ QF_GETLIST_FILEWINID;
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5911 }
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5912
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5913 if (dict_find(what, (char_u *)"title", -1) != NULL)
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5914 flags |= QF_GETLIST_TITLE;
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5915
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5916 if (dict_find(what, (char_u *)"nr", -1) != NULL)
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5917 flags |= QF_GETLIST_NR;
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5918
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5919 if (dict_find(what, (char_u *)"winid", -1) != NULL)
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5920 flags |= QF_GETLIST_WINID;
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5921
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5922 if (dict_find(what, (char_u *)"context", -1) != NULL)
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5923 flags |= QF_GETLIST_CONTEXT;
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5924
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5925 if (dict_find(what, (char_u *)"id", -1) != NULL)
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5926 flags |= QF_GETLIST_ID;
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5927
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5928 if (dict_find(what, (char_u *)"items", -1) != NULL)
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5929 flags |= QF_GETLIST_ITEMS;
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
5930
12465
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5931 if (dict_find(what, (char_u *)"idx", -1) != NULL)
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5932 flags |= QF_GETLIST_IDX;
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5933
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5934 if (dict_find(what, (char_u *)"size", -1) != NULL)
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5935 flags |= QF_GETLIST_SIZE;
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5936
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5937 if (dict_find(what, (char_u *)"changedtick", -1) != NULL)
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5938 flags |= QF_GETLIST_TICK;
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5939
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5940 if (loclist && dict_find(what, (char_u *)"filewinid", -1) != NULL)
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5941 flags |= QF_GETLIST_FILEWINID;
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
5942
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5943 return flags;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5944 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5945
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5946 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5947 * Return the quickfix list index based on 'nr' or 'id' in 'what'.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5948 * If 'nr' and 'id' are not present in 'what' then return the current
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5949 * quickfix list index.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5950 * If 'nr' is zero then return the current quickfix list index.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5951 * If 'nr' is '$' then return the last quickfix list index.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5952 * If 'id' is present then return the index of the quickfix list with that id.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5953 * If 'id' is zero then return the quickfix list index specified by 'nr'.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5954 * Return -1, if quickfix list is not present or if the stack is empty.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5955 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5956 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5957 qf_getprop_qfidx(qf_info_T *qi, dict_T *what)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5958 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5959 int qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5960 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5961
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5962 qf_idx = qi->qf_curlist; // default is the current list
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5963 if ((di = dict_find(what, (char_u *)"nr", -1)) != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5964 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5965 // Use the specified quickfix/location list
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5966 if (di->di_tv.v_type == VAR_NUMBER)
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5967 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5968 // for zero use the current list
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5969 if (di->di_tv.vval.v_number != 0)
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5970 {
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5971 qf_idx = di->di_tv.vval.v_number - 1;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5972 if (qf_idx < 0 || qf_idx >= qi->qf_listcount)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
5973 qf_idx = INVALID_QFIDX;
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5974 }
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5975 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5976 else if (di->di_tv.v_type == VAR_STRING
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5977 && di->di_tv.vval.v_string != NULL
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5978 && STRCMP(di->di_tv.vval.v_string, "$") == 0)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5979 // Get the last quickfix list number
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5980 qf_idx = qi->qf_listcount - 1;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5981 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
5982 qf_idx = INVALID_QFIDX;
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5983 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5984
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5985 if ((di = dict_find(what, (char_u *)"id", -1)) != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5986 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5987 // Look for a list with the specified id
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5988 if (di->di_tv.v_type == VAR_NUMBER)
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5989 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5990 // For zero, use the current list or the list specified by 'nr'
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5991 if (di->di_tv.vval.v_number != 0)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5992 qf_idx = qf_id2nr(qi, di->di_tv.vval.v_number);
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5993 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5994 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
5995 qf_idx = INVALID_QFIDX;
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5996 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5997
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5998 return qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5999 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6000
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6001 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6002 * Return default values for quickfix list properties in retdict.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6003 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6004 static int
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6005 qf_getprop_defaults(qf_info_T *qi, int flags, int locstack, dict_T *retdict)
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6006 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6007 int status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6008
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6009 if (flags & QF_GETLIST_TITLE)
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6010 status = dict_add_string(retdict, "title", (char_u *)"");
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6011 if ((status == OK) && (flags & QF_GETLIST_ITEMS))
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6012 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6013 list_T *l = list_alloc();
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6014 if (l != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6015 status = dict_add_list(retdict, "items", l);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6016 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6017 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6018 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6019 if ((status == OK) && (flags & QF_GETLIST_NR))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6020 status = dict_add_number(retdict, "nr", 0);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6021 if ((status == OK) && (flags & QF_GETLIST_WINID))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6022 status = dict_add_number(retdict, "winid", qf_winid(qi));
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6023 if ((status == OK) && (flags & QF_GETLIST_CONTEXT))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6024 status = dict_add_string(retdict, "context", (char_u *)"");
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6025 if ((status == OK) && (flags & QF_GETLIST_ID))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6026 status = dict_add_number(retdict, "id", 0);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6027 if ((status == OK) && (flags & QF_GETLIST_IDX))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6028 status = dict_add_number(retdict, "idx", 0);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6029 if ((status == OK) && (flags & QF_GETLIST_SIZE))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6030 status = dict_add_number(retdict, "size", 0);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6031 if ((status == OK) && (flags & QF_GETLIST_TICK))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6032 status = dict_add_number(retdict, "changedtick", 0);
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6033 if ((status == OK) && locstack && (flags & QF_GETLIST_FILEWINID))
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6034 status = dict_add_number(retdict, "filewinid", 0);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6035
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6036 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6037 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6038
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6039 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6040 * Return the quickfix list title as 'title' in retdict
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6041 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6042 static int
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6043 qf_getprop_title(qf_list_T *qfl, dict_T *retdict)
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6044 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6045 return dict_add_string(retdict, "title", qfl->qf_title);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6046 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6047
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6048 /*
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6049 * Returns the identifier of the window used to display files from a location
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6050 * list. If there is no associated window, then returns 0. Useful only when
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6051 * called from a location list window.
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6052 */
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6053 static int
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6054 qf_getprop_filewinid(win_T *wp, qf_info_T *qi, dict_T *retdict)
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6055 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6056 int winid = 0;
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6057
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6058 if (wp != NULL && IS_LL_WINDOW(wp))
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6059 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6060 win_T *ll_wp = qf_find_win_with_loclist(qi);
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6061 if (ll_wp != NULL)
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6062 winid = ll_wp->w_id;
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6063 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6064
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6065 return dict_add_number(retdict, "filewinid", winid);
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6066 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6067
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6068 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6069 * Return the quickfix list items/entries as 'items' in retdict
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6070 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6071 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6072 qf_getprop_items(qf_info_T *qi, int qf_idx, dict_T *retdict)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6073 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6074 int status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6075 list_T *l = list_alloc();
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6076 if (l != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6077 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6078 (void)get_errorlist(qi, NULL, qf_idx, l);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6079 dict_add_list(retdict, "items", l);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6080 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6081 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6082 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6083
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6084 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6085 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6086
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6087 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6088 * Return the quickfix list context (if any) as 'context' in retdict.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6089 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6090 static int
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6091 qf_getprop_ctx(qf_list_T *qfl, dict_T *retdict)
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6092 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6093 int status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6094 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6095
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6096 if (qfl->qf_ctx != NULL)
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6097 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6098 di = dictitem_alloc((char_u *)"context");
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6099 if (di != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6100 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6101 copy_tv(qfl->qf_ctx, &di->di_tv);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6102 status = dict_add(retdict, di);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6103 if (status == FAIL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6104 dictitem_free(di);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6105 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6106 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6107 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6108 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6109 else
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6110 status = dict_add_string(retdict, "context", (char_u *)"");
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6111
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6112 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6113 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6114
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6115 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6116 * Return the current quickfix list index as 'idx' in retdict
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6117 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6118 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6119 qf_getprop_idx(qf_info_T *qi, int qf_idx, dict_T *retdict)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6120 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6121 int curidx = qi->qf_lists[qf_idx].qf_index;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
6122 if (qf_list_empty(qi, qf_idx))
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6123 // For empty lists, current index is set to 0
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6124 curidx = 0;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6125 return dict_add_number(retdict, "idx", curidx);
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6126 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6127
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6128 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6129 * Return quickfix/location list details (title) as a
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6130 * dictionary. 'what' contains the details to return. If 'list_idx' is -1,
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6131 * then current list is used. Otherwise the specified list is used.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6132 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6133 int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6134 qf_get_properties(win_T *wp, dict_T *what, dict_T *retdict)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6135 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6136 qf_info_T *qi = &ql_info;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6137 qf_list_T *qfl;
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6138 int status = OK;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6139 int qf_idx = INVALID_QFIDX;
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6140 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6141 int flags = QF_GETLIST_NONE;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6142
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6143 if ((di = dict_find(what, (char_u *)"lines", -1)) != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6144 return qf_get_list_from_lines(what, di, retdict);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6145
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6146 if (wp != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6147 qi = GET_LOC_LIST(wp);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6148
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6149 flags = qf_getprop_keys2flags(what, (wp != NULL));
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6150
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6151 if (!qf_stack_empty(qi))
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6152 qf_idx = qf_getprop_qfidx(qi, what);
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
6153
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6154 // List is not present or is empty
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6155 if (qf_stack_empty(qi) || qf_idx == INVALID_QFIDX)
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6156 return qf_getprop_defaults(qi, flags, wp != NULL, retdict);
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
6157
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6158 qfl = &qi->qf_lists[qf_idx];
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6159
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6160 if (flags & QF_GETLIST_TITLE)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6161 status = qf_getprop_title(qfl, retdict);
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6162 if ((status == OK) && (flags & QF_GETLIST_NR))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6163 status = dict_add_number(retdict, "nr", qf_idx + 1);
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6164 if ((status == OK) && (flags & QF_GETLIST_WINID))
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6165 status = dict_add_number(retdict, "winid", qf_winid(qi));
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6166 if ((status == OK) && (flags & QF_GETLIST_ITEMS))
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6167 status = qf_getprop_items(qi, qf_idx, retdict);
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6168 if ((status == OK) && (flags & QF_GETLIST_CONTEXT))
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6169 status = qf_getprop_ctx(qfl, retdict);
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
6170 if ((status == OK) && (flags & QF_GETLIST_ID))
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6171 status = dict_add_number(retdict, "id", qfl->qf_id);
12465
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
6172 if ((status == OK) && (flags & QF_GETLIST_IDX))
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6173 status = qf_getprop_idx(qi, qf_idx, retdict);
12465
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
6174 if ((status == OK) && (flags & QF_GETLIST_SIZE))
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6175 status = dict_add_number(retdict, "size", qfl->qf_count);
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6176 if ((status == OK) && (flags & QF_GETLIST_TICK))
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6177 status = dict_add_number(retdict, "changedtick", qfl->qf_changedtick);
14664
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6178 if ((status == OK) && (wp != NULL) && (flags & QF_GETLIST_FILEWINID))
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6179 status = qf_getprop_filewinid(wp, qi, retdict);
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6180
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6181 return status;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6182 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6183
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6184 /*
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6185 * Add a new quickfix entry to list at 'qf_idx' in the stack 'qi' from the
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6186 * items in the dict 'd'. If it is a valid error entry, then set 'valid_entry'
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6187 * to TRUE.
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6188 */
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6189 static int
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6190 qf_add_entry_from_dict(
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6191 qf_info_T *qi,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6192 int qf_idx,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6193 dict_T *d,
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6194 int first_entry,
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6195 int *valid_entry)
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6196 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6197 static int did_bufnr_emsg;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6198 char_u *filename, *module, *pattern, *text, *type;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6199 int bufnum, valid, status, col, vcol, nr;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6200 long lnum;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6201
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6202 if (first_entry)
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6203 did_bufnr_emsg = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6204
15146
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6205 filename = dict_get_string(d, (char_u *)"filename", TRUE);
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6206 module = dict_get_string(d, (char_u *)"module", TRUE);
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6207 bufnum = (int)dict_get_number(d, (char_u *)"bufnr");
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6208 lnum = (int)dict_get_number(d, (char_u *)"lnum");
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6209 col = (int)dict_get_number(d, (char_u *)"col");
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6210 vcol = (int)dict_get_number(d, (char_u *)"vcol");
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6211 nr = (int)dict_get_number(d, (char_u *)"nr");
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6212 type = dict_get_string(d, (char_u *)"type", TRUE);
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6213 pattern = dict_get_string(d, (char_u *)"pattern", TRUE);
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6214 text = dict_get_string(d, (char_u *)"text", TRUE);
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6215 if (text == NULL)
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6216 text = vim_strsave((char_u *)"");
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6217
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6218 valid = TRUE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6219 if ((filename == NULL && bufnum == 0) || (lnum == 0 && pattern == NULL))
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6220 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6221
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6222 // Mark entries with non-existing buffer number as not valid. Give the
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6223 // error message only once.
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6224 if (bufnum != 0 && (buflist_findnr(bufnum) == NULL))
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6225 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6226 if (!did_bufnr_emsg)
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6227 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6228 did_bufnr_emsg = TRUE;
15490
98c35d312987 patch 8.1.0753: printf format not checked for semsg()
Bram Moolenaar <Bram@vim.org>
parents: 15470
diff changeset
6229 semsg(_("E92: Buffer %d not found"), bufnum);
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6230 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6231 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6232 bufnum = 0;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6233 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6234
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6235 // If the 'valid' field is present it overrules the detected value.
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6236 if ((dict_find(d, (char_u *)"valid", -1)) != NULL)
15146
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6237 valid = (int)dict_get_number(d, (char_u *)"valid");
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6238
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6239 status = qf_add_entry(qi,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6240 qf_idx,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6241 NULL, // dir
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6242 filename,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6243 module,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6244 bufnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6245 text,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6246 lnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6247 col,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6248 vcol, // vis_col
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6249 pattern, // search pattern
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6250 nr,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6251 type == NULL ? NUL : *type,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6252 valid);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6253
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6254 vim_free(filename);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6255 vim_free(module);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6256 vim_free(pattern);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6257 vim_free(text);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6258 vim_free(type);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6259
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6260 if (valid)
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6261 *valid_entry = TRUE;
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6262
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6263 return status;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6264 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6265
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6266 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6267 * Add list of entries to quickfix/location list. Each list entry is
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6268 * a dictionary with item information.
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6269 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6270 static int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6271 qf_add_entries(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6272 qf_info_T *qi,
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6273 int qf_idx,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6274 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6275 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6276 int action)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6277 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6278 qf_list_T *qfl = &qi->qf_lists[qf_idx];
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6279 listitem_T *li;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6280 dict_T *d;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
6281 qfline_T *old_last = NULL;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6282 int retval = OK;
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6283 int valid_entry = FALSE;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6284
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6285 if (action == ' ' || qf_idx == qi->qf_listcount)
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6286 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6287 // make place for a new list
3965
eccae034465b updated for version 7.3.738
Bram Moolenaar <bram@vim.org>
parents: 3949
diff changeset
6288 qf_new_list(qi, title);
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6289 qf_idx = qi->qf_curlist;
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6290 qfl = &qi->qf_lists[qf_idx];
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6291 }
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
6292 else if (action == 'a' && !qf_list_empty(qi, qf_idx))
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6293 // Adding to existing list, use last entry.
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6294 old_last = qfl->qf_last;
277
fe16c18c24a7 updated for version 7.0074
vimboss
parents: 273
diff changeset
6295 else if (action == 'r')
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6296 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6297 qf_free_items(qfl);
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6298 qf_store_title(qfl, title);
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6299 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6300
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6301 for (li = list->lv_first; li != NULL; li = li->li_next)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6302 {
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6303 if (li->li_tv.v_type != VAR_DICT)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6304 continue; // Skip non-dict items
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6305
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6306 d = li->li_tv.vval.v_dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6307 if (d == NULL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6308 continue;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6309
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6310 retval = qf_add_entry_from_dict(qi, qf_idx, d, li == list->lv_first,
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6311 &valid_entry);
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6312 if (retval == FAIL)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6313 break;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6314 }
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6315
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6316 // Check if any valid error entries are added to the list.
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6317 if (valid_entry)
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6318 qfl->qf_nonevalid = FALSE;
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6319 else if (qfl->qf_index == 0)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6320 // no valid entry
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6321 qfl->qf_nonevalid = TRUE;
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6322
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6323 // If not appending to the list, set the current error to the first entry
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6324 if (action != 'a')
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6325 qfl->qf_ptr = qfl->qf_start;
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6326
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6327 // Update the current error index if not appending to the list or if the
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6328 // list was empty before and it is not empty now.
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6329 if ((action != 'a' || qfl->qf_index == 0) && !qf_list_empty(qi, qf_idx))
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6330 qfl->qf_index = 1;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6331
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6332 // Don't update the cursor in quickfix window when appending entries
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
6333 qf_update_buffer(qi, old_last);
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6334
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6335 return retval;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6336 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6337
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6338 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6339 * Get the quickfix list index from 'nr' or 'id'
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6340 */
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6341 static int
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6342 qf_setprop_get_qfidx(
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6343 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6344 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6345 int action,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6346 int *newlist)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6347 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6348 dictitem_T *di;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6349 int qf_idx = qi->qf_curlist; // default is the current list
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6350
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6351 if ((di = dict_find(what, (char_u *)"nr", -1)) != NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6352 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6353 // Use the specified quickfix/location list
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6354 if (di->di_tv.v_type == VAR_NUMBER)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6355 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6356 // for zero use the current list
11445
461ac47c3793 patch 8.0.0606: cannot set the context for a specified quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11443
diff changeset
6357 if (di->di_tv.vval.v_number != 0)
461ac47c3793 patch 8.0.0606: cannot set the context for a specified quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11443
diff changeset
6358 qf_idx = di->di_tv.vval.v_number - 1;
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6359
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6360 if ((action == ' ' || action == 'a') && qf_idx == qi->qf_listcount)
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6361 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6362 // When creating a new list, accept qf_idx pointing to the next
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6363 // non-available list and add the new list at the end of the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6364 // stack.
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6365 *newlist = TRUE;
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6366 qf_idx = qf_stack_empty(qi) ? 0 : qi->qf_listcount - 1;
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6367 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6368 else if (qf_idx < 0 || qf_idx >= qi->qf_listcount)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6369 return INVALID_QFIDX;
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6370 else if (action != ' ')
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6371 *newlist = FALSE; // use the specified list
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6372 }
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6373 else if (di->di_tv.v_type == VAR_STRING
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6374 && di->di_tv.vval.v_string != NULL
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6375 && STRCMP(di->di_tv.vval.v_string, "$") == 0)
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6376 {
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6377 if (!qf_stack_empty(qi))
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6378 qf_idx = qi->qf_listcount - 1;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6379 else if (*newlist)
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6380 qf_idx = 0;
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6381 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6382 return INVALID_QFIDX;
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6383 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6384 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6385 return INVALID_QFIDX;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6386 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6387
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6388 if (!*newlist && (di = dict_find(what, (char_u *)"id", -1)) != NULL)
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
6389 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6390 // Use the quickfix/location list with the specified id
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6391 if (di->di_tv.v_type != VAR_NUMBER)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6392 return INVALID_QFIDX;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6393
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6394 return qf_id2nr(qi, di->di_tv.vval.v_number);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6395 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6396
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6397 return qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6398 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6399
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6400 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6401 * Set the quickfix list title.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6402 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6403 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6404 qf_setprop_title(qf_info_T *qi, int qf_idx, dict_T *what, dictitem_T *di)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6405 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6406 qf_list_T *qfl = &qi->qf_lists[qf_idx];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6407
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6408 if (di->di_tv.v_type != VAR_STRING)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6409 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6410
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6411 vim_free(qfl->qf_title);
15146
7903dce131d4 patch 8.1.0583: using illogical name for get_dict_number()/get_dict_string()
Bram Moolenaar <Bram@vim.org>
parents: 15042
diff changeset
6412 qfl->qf_title = dict_get_string(what, (char_u *)"title", TRUE);
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6413 if (qf_idx == qi->qf_curlist)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6414 qf_update_win_titlevar(qi);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6415
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6416 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6417 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6418
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6419 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6420 * Set quickfix list items/entries.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6421 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6422 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6423 qf_setprop_items(qf_info_T *qi, int qf_idx, dictitem_T *di, int action)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6424 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6425 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6426 char_u *title_save;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6427
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6428 if (di->di_tv.v_type != VAR_LIST)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6429 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6430
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6431 title_save = vim_strsave(qi->qf_lists[qf_idx].qf_title);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6432 retval = qf_add_entries(qi, qf_idx, di->di_tv.vval.v_list,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6433 title_save, action == ' ' ? 'a' : action);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6434 vim_free(title_save);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6435
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6436 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6437 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6438
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6439 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6440 * Set quickfix list items/entries from a list of lines.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6441 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6442 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6443 qf_setprop_items_from_lines(
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6444 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6445 int qf_idx,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6446 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6447 dictitem_T *di,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6448 int action)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6449 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6450 char_u *errorformat = p_efm;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6451 dictitem_T *efm_di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6452 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6453
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6454 // Use the user supplied errorformat settings (if present)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6455 if ((efm_di = dict_find(what, (char_u *)"efm", -1)) != NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6456 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6457 if (efm_di->di_tv.v_type != VAR_STRING ||
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6458 efm_di->di_tv.vval.v_string == NULL)
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
6459 return FAIL;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6460 errorformat = efm_di->di_tv.vval.v_string;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6461 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6462
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6463 // Only a List value is supported
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6464 if (di->di_tv.v_type != VAR_LIST || di->di_tv.vval.v_list == NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6465 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6466
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6467 if (action == 'r')
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6468 qf_free_items(&qi->qf_lists[qf_idx]);
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6469 if (qf_init_ext(qi, qf_idx, NULL, NULL, &di->di_tv, errorformat,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6470 FALSE, (linenr_T)0, (linenr_T)0, NULL, NULL) > 0)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6471 retval = OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6472
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6473 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6474 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6475
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6476 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6477 * Set quickfix list context.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6478 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6479 static int
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6480 qf_setprop_context(qf_list_T *qfl, dictitem_T *di)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6481 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6482 typval_T *ctx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6483
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6484 free_tv(qfl->qf_ctx);
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6485 ctx = alloc_tv();
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6486 if (ctx != NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6487 copy_tv(&di->di_tv, ctx);
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6488 qfl->qf_ctx = ctx;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6489
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6490 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6491 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6492
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6493 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6494 * Set the current index in the specified quickfix list
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6495 */
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6496 static int
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6497 qf_setprop_curidx(qf_info_T *qi, qf_list_T *qfl, dictitem_T *di)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6498 {
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6499 int denote = FALSE;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6500 int newidx;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6501 int old_qfidx;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6502 qfline_T *qf_ptr;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6503
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6504 // If the specified index is '$', then use the last entry
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6505 if (di->di_tv.v_type == VAR_STRING
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6506 && di->di_tv.vval.v_string != NULL
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6507 && STRCMP(di->di_tv.vval.v_string, "$") == 0)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6508 newidx = qfl->qf_count;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6509 else
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6510 {
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6511 // Otherwise use the specified index
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6512 newidx = tv_get_number_chk(&di->di_tv, &denote);
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6513 if (denote)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6514 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6515 }
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6516
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6517 if (newidx < 1) // sanity check
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6518 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6519 if (newidx > qfl->qf_count)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6520 newidx = qfl->qf_count;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6521
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6522 old_qfidx = qfl->qf_index;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6523 qf_ptr = get_nth_entry(qfl, newidx, &newidx);
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6524 if (qf_ptr == NULL)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6525 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6526 qfl->qf_ptr = qf_ptr;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6527 qfl->qf_index = newidx;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6528
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6529 // If the current list is modified and it is displayed in the quickfix
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6530 // window, then Update it.
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6531 if (qi->qf_lists[qi->qf_curlist].qf_id == qfl->qf_id)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6532 qf_win_pos_update(qi, old_qfidx);
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6533
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6534 return OK;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6535 }
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6536
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6537 /*
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6538 * Set quickfix/location list properties (title, items, context).
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6539 * Also used to add items from parsing a list of lines.
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
6540 * Used by the setqflist() and setloclist() Vim script functions.
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6541 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6542 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6543 qf_set_properties(qf_info_T *qi, dict_T *what, int action, char_u *title)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6544 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6545 dictitem_T *di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6546 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6547 int qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6548 int newlist = FALSE;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6549 qf_list_T *qfl;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6550
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6551 if (action == ' ' || qf_stack_empty(qi))
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6552 newlist = TRUE;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6553
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6554 qf_idx = qf_setprop_get_qfidx(qi, what, action, &newlist);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6555 if (qf_idx == INVALID_QFIDX) // List not found
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6556 return FAIL;
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
6557
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6558 if (newlist)
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6559 {
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6560 qi->qf_curlist = qf_idx;
12048
ebd313aa5a6c patch 8.0.0904: cannot set a location list from text
Christian Brabandt <cb@256bit.org>
parents: 11800
diff changeset
6561 qf_new_list(qi, title);
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6562 qf_idx = qi->qf_curlist;
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6563 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6564
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6565 qfl = &qi->qf_lists[qf_idx];
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6566 if ((di = dict_find(what, (char_u *)"title", -1)) != NULL)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6567 retval = qf_setprop_title(qi, qf_idx, what, di);
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6568 if ((di = dict_find(what, (char_u *)"items", -1)) != NULL)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6569 retval = qf_setprop_items(qi, qf_idx, di, action);
12303
ec7a4fd21dd5 patch 8.0.1031: "text" argument for getqflist() is confusing
Christian Brabandt <cb@256bit.org>
parents: 12299
diff changeset
6570 if ((di = dict_find(what, (char_u *)"lines", -1)) != NULL)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6571 retval = qf_setprop_items_from_lines(qi, qf_idx, what, di, action);
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6572 if ((di = dict_find(what, (char_u *)"context", -1)) != NULL)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6573 retval = qf_setprop_context(qfl, di);
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6574 if ((di = dict_find(what, (char_u *)"idx", -1)) != NULL)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6575 retval = qf_setprop_curidx(qi, qfl, di);
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6576
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6577 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6578 qf_list_changed(qfl);
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6579
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6580 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6581 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6582
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6583 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6584 * Find the non-location list window with the specified location list stack in
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6585 * the current tabpage.
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6586 */
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6587 static win_T *
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6588 find_win_with_ll(qf_info_T *qi)
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6589 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6590 win_T *wp = NULL;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6591
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6592 FOR_ALL_WINDOWS(wp)
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6593 if ((wp->w_llist == qi) && !bt_quickfix(wp->w_buffer))
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6594 return wp;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6595
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6596 return NULL;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6597 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6598
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6599 /*
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6600 * Free the entire quickfix/location list stack.
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6601 * If the quickfix/location list window is open, then clear it.
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6602 */
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6603 static void
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6604 qf_free_stack(win_T *wp, qf_info_T *qi)
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6605 {
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6606 win_T *qfwin = qf_find_win(qi);
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6607 win_T *llwin = NULL;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6608 win_T *orig_wp = wp;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6609
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6610 if (qfwin != NULL)
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6611 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6612 // If the quickfix/location list window is open, then clear it
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6613 if (qi->qf_curlist < qi->qf_listcount)
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6614 qf_free(&qi->qf_lists[qi->qf_curlist]);
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6615 qf_update_buffer(qi, NULL);
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6616 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6617
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6618 if (wp != NULL && IS_LL_WINDOW(wp))
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6619 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6620 // If in the location list window, then use the non-location list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6621 // window with this location list (if present)
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6622 llwin = find_win_with_ll(qi);
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6623 if (llwin != NULL)
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6624 wp = llwin;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6625 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6626
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6627 qf_free_all(wp);
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6628 if (wp == NULL)
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6629 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6630 // quickfix list
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6631 qi->qf_curlist = 0;
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6632 qi->qf_listcount = 0;
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6633 }
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6634 else if (IS_LL_WINDOW(orig_wp))
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6635 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6636 // If the location list window is open, then create a new empty
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6637 // location list
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6638 qf_info_T *new_ll = qf_alloc_stack(QFLT_LOCATION);
11378
2ed7a34ecc54 patch 8.0.0574: get only one quickfix list after :caddbuf
Christian Brabandt <cb@256bit.org>
parents: 11360
diff changeset
6639
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6640 // first free the list reference in the location list window
11398
30af33f4d353 patch 8.0.0584: memory leak when executing quickfix tests
Christian Brabandt <cb@256bit.org>
parents: 11390
diff changeset
6641 ll_free_all(&orig_wp->w_llist_ref);
30af33f4d353 patch 8.0.0584: memory leak when executing quickfix tests
Christian Brabandt <cb@256bit.org>
parents: 11390
diff changeset
6642
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6643 orig_wp->w_llist_ref = new_ll;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6644 if (llwin != NULL)
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6645 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6646 llwin->w_llist = new_ll;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6647 new_ll->qf_refcount++;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6648 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6649 }
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6650 }
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6651
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6652 /*
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6653 * Populate the quickfix list with the items supplied in the list
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6654 * of dictionaries. "title" will be copied to w:quickfix_title.
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6655 * "action" is 'a' for add, 'r' for replace. Otherwise create a new list.
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6656 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6657 int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6658 set_errorlist(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6659 win_T *wp,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6660 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6661 int action,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6662 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6663 dict_T *what)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6664 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6665 qf_info_T *qi = &ql_info;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6666 int retval = OK;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6667
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6668 if (wp != NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6669 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6670 qi = ll_get_or_alloc_list(wp);
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6671 if (qi == NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6672 return FAIL;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6673 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6674
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6675 if (action == 'f')
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6676 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6677 // Free the entire quickfix or location list stack
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6678 qf_free_stack(wp, qi);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6679 return OK;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6680 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6681
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6682 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6683
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6684 if (what != NULL)
12048
ebd313aa5a6c patch 8.0.0904: cannot set a location list from text
Christian Brabandt <cb@256bit.org>
parents: 11800
diff changeset
6685 retval = qf_set_properties(qi, what, action, title);
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6686 else
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6687 {
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6688 retval = qf_add_entries(qi, qi->qf_curlist, list, title, action);
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6689 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6690 qf_list_changed(&qi->qf_lists[qi->qf_curlist]);
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6691 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6692
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6693 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6694
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6695 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6696 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6697
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6698 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6699 * Mark the context as in use for all the lists in a quickfix stack.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6700 */
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6701 static int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6702 mark_quickfix_ctx(qf_info_T *qi, int copyID)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6703 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6704 int i;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6705 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6706 typval_T *ctx;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6707
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6708 for (i = 0; i < LISTCOUNT && !abort; ++i)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6709 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6710 ctx = qi->qf_lists[i].qf_ctx;
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6711 if (ctx != NULL && ctx->v_type != VAR_NUMBER
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6712 && ctx->v_type != VAR_STRING && ctx->v_type != VAR_FLOAT)
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6713 abort = set_ref_in_item(ctx, copyID, NULL, NULL);
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6714 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6715
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6716 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6717 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6718
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6719 /*
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6720 * Mark the context of the quickfix list and the location lists (if present) as
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6721 * "in use". So that garbage collection doesn't free the context.
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6722 */
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6723 int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6724 set_ref_in_quickfix(int copyID)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6725 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6726 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6727 tabpage_T *tp;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6728 win_T *win;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6729
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6730 abort = mark_quickfix_ctx(&ql_info, copyID);
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6731 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6732 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6733
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6734 FOR_ALL_TAB_WINDOWS(tp, win)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6735 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6736 if (win->w_llist != NULL)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6737 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6738 abort = mark_quickfix_ctx(win->w_llist, copyID);
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6739 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6740 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6741 }
13074
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6742 if (IS_LL_WINDOW(win) && (win->w_llist_ref->qf_refcount == 1))
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6743 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6744 // In a location list window and none of the other windows is
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6745 // referring to this location list. Mark the location list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6746 // context as still in use.
13074
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6747 abort = mark_quickfix_ctx(win->w_llist_ref, copyID);
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6748 if (abort)
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6749 return abort;
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6750 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6751 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6752
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6753 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6754 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6755 #endif
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6756
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
6757 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6758 * ":[range]cbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6759 * ":[range]caddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6760 * ":[range]cgetbuffer [bufnr]" command.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6761 * ":[range]lbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6762 * ":[range]laddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6763 * ":[range]lgetbuffer [bufnr]" command.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6764 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6765 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6766 ex_cbuffer(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6767 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6768 buf_T *buf = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6769 qf_info_T *qi = &ql_info;
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6770 char_u *au_name = NULL;
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6771 int res;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6772 int_u save_qfid;
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6773 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6774
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6775 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6776 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6777 case CMD_cbuffer: au_name = (char_u *)"cbuffer"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6778 case CMD_cgetbuffer: au_name = (char_u *)"cgetbuffer"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6779 case CMD_caddbuffer: au_name = (char_u *)"caddbuffer"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6780 case CMD_lbuffer: au_name = (char_u *)"lbuffer"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6781 case CMD_lgetbuffer: au_name = (char_u *)"lgetbuffer"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6782 case CMD_laddbuffer: au_name = (char_u *)"laddbuffer"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6783 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6784 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6785 if (au_name != NULL && apply_autocmds(EVENT_QUICKFIXCMDPRE, au_name,
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6786 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6787 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6788 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6789 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6790 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6791 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6792 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6793
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6794 // Must come after autocommands.
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
6795 if (is_loclist_cmd(eap->cmdidx))
13076
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6796 {
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6797 qi = ll_get_or_alloc_list(curwin);
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6798 if (qi == NULL)
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6799 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6800 wp = curwin;
13076
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6801 }
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6802
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6803 if (*eap->arg == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6804 buf = curbuf;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6805 else if (*skipwhite(skipdigits(eap->arg)) == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6806 buf = buflist_findnr(atoi((char *)eap->arg));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6807 if (buf == NULL)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
6808 emsg(_(e_invarg));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6809 else if (buf->b_ml.ml_mfp == NULL)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
6810 emsg(_("E681: Buffer is not loaded"));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6811 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6812 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6813 if (eap->addr_count == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6814 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6815 eap->line1 = 1;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6816 eap->line2 = buf->b_ml.ml_line_count;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6817 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6818 if (eap->line1 < 1 || eap->line1 > buf->b_ml.ml_line_count
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6819 || eap->line2 < 1 || eap->line2 > buf->b_ml.ml_line_count)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
6820 emsg(_(e_invrange));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6821 else
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6822 {
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
6823 char_u *qf_title = qf_cmdtitle(*eap->cmdlinep);
2411
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6824
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6825 if (buf->b_sfname)
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6826 {
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6827 vim_snprintf((char *)IObuff, IOSIZE, "%s (%s)",
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6828 (char *)qf_title, (char *)buf->b_sfname);
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6829 qf_title = IObuff;
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6830 }
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6831
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6832 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6833
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6834 res = qf_init_ext(qi, qi->qf_curlist, NULL, buf, NULL, p_efm,
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6835 (eap->cmdidx != CMD_caddbuffer
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6836 && eap->cmdidx != CMD_laddbuffer),
2411
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6837 eap->line1, eap->line2,
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6838 qf_title, NULL);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6839 if (qf_stack_empty(qi))
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6840 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6841 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6842 return;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6843 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6844 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6845 qf_list_changed(&qi->qf_lists[qi->qf_curlist]);
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6846
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6847 // Remember the current quickfix list identifier, so that we can
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6848 // check for autocommands changing the current quickfix list.
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6849 save_qfid = qi->qf_lists[qi->qf_curlist].qf_id;
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6850 if (au_name != NULL)
14085
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6851 {
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6852 buf_T *curbuf_old = curbuf;
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6853
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6854 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6855 curbuf->b_fname, TRUE, curbuf);
14085
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6856 if (curbuf != curbuf_old)
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6857 // Autocommands changed buffer, don't jump now, "qi" may
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6858 // be invalid.
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6859 res = 0;
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6860 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6861 // Jump to the first error for a new list and if autocmds didn't
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6862 // free the list.
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6863 if (res > 0 && (eap->cmdidx == CMD_cbuffer ||
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6864 eap->cmdidx == CMD_lbuffer)
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6865 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6866 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6867 qf_jump_first(qi, save_qfid, eap->forceit);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6868
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6869 decr_quickfix_busy();
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6870 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6871 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6872 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6873
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
6874 #if defined(FEAT_EVAL) || defined(PROTO)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6875 /*
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6876 * ":cexpr {expr}", ":cgetexpr {expr}", ":caddexpr {expr}" command.
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6877 * ":lexpr {expr}", ":lgetexpr {expr}", ":laddexpr {expr}" command.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6878 */
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6879 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6880 ex_cexpr(exarg_T *eap)
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6881 {
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6882 typval_T *tv;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6883 qf_info_T *qi = &ql_info;
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6884 char_u *au_name = NULL;
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6885 int res;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6886 int_u save_qfid;
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6887 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6888
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6889 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6890 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6891 case CMD_cexpr: au_name = (char_u *)"cexpr"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6892 case CMD_cgetexpr: au_name = (char_u *)"cgetexpr"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6893 case CMD_caddexpr: au_name = (char_u *)"caddexpr"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6894 case CMD_lexpr: au_name = (char_u *)"lexpr"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6895 case CMD_lgetexpr: au_name = (char_u *)"lgetexpr"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6896 case CMD_laddexpr: au_name = (char_u *)"laddexpr"; break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6897 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6898 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6899 if (au_name != NULL && apply_autocmds(EVENT_QUICKFIXCMDPRE, au_name,
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6900 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6901 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6902 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6903 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6904 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6905 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6906 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6907
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
6908 if (is_loclist_cmd(eap->cmdidx))
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6909 {
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6910 qi = ll_get_or_alloc_list(curwin);
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6911 if (qi == NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6912 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6913 wp = curwin;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6914 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6915
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6916 // Evaluate the expression. When the result is a string or a list we can
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6917 // use it to fill the errorlist.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6918 tv = eval_expr(eap->arg, NULL);
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6919 if (tv != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6920 {
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6921 if ((tv->v_type == VAR_STRING && tv->vval.v_string != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6922 || (tv->v_type == VAR_LIST && tv->vval.v_list != NULL))
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6923 {
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6924 incr_quickfix_busy();
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6925 res = qf_init_ext(qi, qi->qf_curlist, NULL, NULL, tv, p_efm,
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6926 (eap->cmdidx != CMD_caddexpr
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6927 && eap->cmdidx != CMD_laddexpr),
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
6928 (linenr_T)0, (linenr_T)0,
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
6929 qf_cmdtitle(*eap->cmdlinep), NULL);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6930 if (qf_stack_empty(qi))
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6931 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6932 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6933 goto cleanup;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6934 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6935 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6936 qf_list_changed(&qi->qf_lists[qi->qf_curlist]);
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6937
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6938 // Remember the current quickfix list identifier, so that we can
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6939 // check for autocommands changing the current quickfix list.
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6940 save_qfid = qi->qf_lists[qi->qf_curlist].qf_id;
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6941 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6942 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6943 curbuf->b_fname, TRUE, curbuf);
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6944
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6945 // Jump to the first error for a new list and if autocmds didn't
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6946 // free the list.
14111
678e326bf7eb patch 8.1.0073: crash when autocommands call setloclist()
Christian Brabandt <cb@256bit.org>
parents: 14085
diff changeset
6947 if (res > 0 && (eap->cmdidx == CMD_cexpr
678e326bf7eb patch 8.1.0073: crash when autocommands call setloclist()
Christian Brabandt <cb@256bit.org>
parents: 14085
diff changeset
6948 || eap->cmdidx == CMD_lexpr)
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6949 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6950 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6951 qf_jump_first(qi, save_qfid, eap->forceit);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6952 decr_quickfix_busy();
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6953 }
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6954 else
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
6955 emsg(_("E777: String or List expected"));
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6956 cleanup:
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6957 free_tv(tv);
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6958 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6959 }
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
6960 #endif
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6961
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6962 /*
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6963 * Get the location list for ":lhelpgrep"
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6964 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6965 static qf_info_T *
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6966 hgr_get_ll(int *new_ll)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6967 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6968 win_T *wp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6969 qf_info_T *qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6970
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6971 // If the current window is a help window, then use it
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6972 if (bt_help(curwin->w_buffer))
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6973 wp = curwin;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6974 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6975 // Find an existing help window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
6976 wp = qf_find_help_win();
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6977
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6978 if (wp == NULL) // Help window not found
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6979 qi = NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6980 else
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6981 qi = wp->w_llist;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6982
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6983 if (qi == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6984 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6985 // Allocate a new location list for help text matches
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6986 if ((qi = qf_alloc_stack(QFLT_LOCATION)) == NULL)
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6987 return NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6988 *new_ll = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6989 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6990
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6991 return qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6992 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6993
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6994 /*
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6995 * Search for a pattern in a help file.
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6996 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6997 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6998 hgr_search_file(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6999 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7000 char_u *fname,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7001 vimconv_T *p_vc,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7002 regmatch_T *p_regmatch)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7003 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7004 FILE *fd;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7005 long lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7006
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7007 fd = mch_fopen((char *)fname, "r");
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7008 if (fd == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7009 return;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7010
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7011 lnum = 1;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7012 while (!vim_fgets(IObuff, IOSIZE, fd) && !got_int)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7013 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7014 char_u *line = IObuff;
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7015
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7016 // Convert a line if 'encoding' is not utf-8 and
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7017 // the line contains a non-ASCII character.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7018 if (p_vc->vc_type != CONV_NONE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7019 && has_non_ascii(IObuff))
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7020 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7021 line = string_convert(p_vc, IObuff, NULL);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7022 if (line == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7023 line = IObuff;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7024 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7025
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7026 if (vim_regexec(p_regmatch, line, (colnr_T)0))
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7027 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7028 int l = (int)STRLEN(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7029
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7030 // remove trailing CR, LF, spaces, etc.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7031 while (l > 0 && line[l - 1] <= ' ')
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7032 line[--l] = NUL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7033
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7034 if (qf_add_entry(qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7035 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7036 NULL, // dir
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7037 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
7038 NULL,
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7039 0,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7040 line,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7041 lnum,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7042 (int)(p_regmatch->startp[0] - line)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7043 + 1, // col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7044 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7045 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7046 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7047 1, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7048 TRUE // valid
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7049 ) == FAIL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7050 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7051 got_int = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7052 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7053 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7054 break;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7055 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7056 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7057 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7058 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7059 ++lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7060 line_breakcheck();
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7061 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7062 fclose(fd);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7063 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7064
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7065 /*
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7066 * Search for a pattern in all the help files in the doc directory under
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7067 * the given directory.
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7068 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7069 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7070 hgr_search_files_in_dir(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7071 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7072 char_u *dirname,
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7073 regmatch_T *p_regmatch,
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7074 vimconv_T *p_vc
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7075 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7076 , char_u *lang
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7077 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7078 )
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7079 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7080 int fcount;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7081 char_u **fnames;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7082 int fi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7083
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7084 // Find all "*.txt" and "*.??x" files in the "doc" directory.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7085 add_pathsep(dirname);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7086 STRCAT(dirname, "doc/*.\\(txt\\|??x\\)");
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7087 if (gen_expand_wildcards(1, &dirname, &fcount,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7088 &fnames, EW_FILE|EW_SILENT) == OK
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7089 && fcount > 0)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7090 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7091 for (fi = 0; fi < fcount && !got_int; ++fi)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7092 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7093 #ifdef FEAT_MULTI_LANG
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7094 // Skip files for a different language.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7095 if (lang != NULL
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7096 && STRNICMP(lang, fnames[fi]
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
7097 + STRLEN(fnames[fi]) - 3, 2) != 0
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7098 && !(STRNICMP(lang, "en", 2) == 0
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7099 && STRNICMP("txt", fnames[fi]
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7100 + STRLEN(fnames[fi]) - 3, 3) == 0))
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7101 continue;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7102 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7103
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7104 hgr_search_file(qi, fnames[fi], p_vc, p_regmatch);
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7105 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7106 FreeWild(fcount, fnames);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7107 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7108 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7109
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7110 /*
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
7111 * Search for a pattern in all the help files in the 'runtimepath'
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
7112 * and add the matches to a quickfix list.
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7113 * 'lang' is the language specifier. If supplied, then only matches in the
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
7114 * specified language are found.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7115 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7116 static void
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7117 hgr_search_in_rtp(qf_info_T *qi, regmatch_T *p_regmatch, char_u *lang)
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7118 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7119 char_u *p;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7120
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7121 vimconv_T vc;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7122
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7123 // Help files are in utf-8 or latin1, convert lines when 'encoding'
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7124 // differs.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7125 vc.vc_type = CONV_NONE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7126 if (!enc_utf8)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7127 convert_setup(&vc, (char_u *)"utf-8", p_enc);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7128
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7129 // Go through all the directories in 'runtimepath'
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7130 p = p_rtp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7131 while (*p != NUL && !got_int)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7132 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7133 copy_option_part(&p, NameBuff, MAXPATHL, ",");
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7134
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7135 hgr_search_files_in_dir(qi, NameBuff, p_regmatch, &vc
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7136 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7137 , lang
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7138 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7139 );
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7140 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7141
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7142 if (vc.vc_type != CONV_NONE)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7143 convert_setup(&vc, NULL, NULL);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7144 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7145
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7146 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7147 * ":helpgrep {pattern}"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7148 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7149 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
7150 ex_helpgrep(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7151 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7152 regmatch_T regmatch;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7153 char_u *save_cpo;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
7154 qf_info_T *qi = &ql_info;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7155 int new_qi = FALSE;
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7156 char_u *au_name = NULL;
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7157 char_u *lang = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7158
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7159 switch (eap->cmdidx)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7160 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7161 case CMD_helpgrep: au_name = (char_u *)"helpgrep"; break;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7162 case CMD_lhelpgrep: au_name = (char_u *)"lhelpgrep"; break;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7163 default: break;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7164 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7165 if (au_name != NULL && apply_autocmds(EVENT_QUICKFIXCMDPRE, au_name,
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7166 curbuf->b_fname, TRUE, curbuf))
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7167 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7168 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7169 if (aborting())
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7170 return;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7171 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7172 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7173
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7174 // Make 'cpoptions' empty, the 'l' flag should not be used here.
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7175 save_cpo = p_cpo;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7176 p_cpo = empty_option;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7177
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
7178 if (is_loclist_cmd(eap->cmdidx))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7179 {
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7180 qi = hgr_get_ll(&new_qi);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7181 if (qi == NULL)
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7182 return;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7183 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7184
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7185 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7186
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7187 #ifdef FEAT_MULTI_LANG
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7188 // Check for a specified language
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7189 lang = check_help_lang(eap->arg);
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7190 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7191 regmatch.regprog = vim_regcomp(eap->arg, RE_MAGIC + RE_STRING);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7192 regmatch.rm_ic = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7193 if (regmatch.regprog != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7194 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7195 qf_list_T *qfl;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7196
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7197 // create a new quickfix list
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
7198 qf_new_list(qi, qf_cmdtitle(*eap->cmdlinep));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7199
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7200 hgr_search_in_rtp(qi, &regmatch, lang);
3257
75217982ea46 updated for version 7.3.397
Bram Moolenaar <bram@vim.org>
parents: 3242
diff changeset
7201
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
7202 vim_regfree(regmatch.regprog);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7203
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7204 qfl = &qi->qf_lists[qi->qf_curlist];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7205 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7206 qfl->qf_ptr = qfl->qf_start;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7207 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7208 qf_list_changed(qfl);
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7209 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7210 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7211
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7212 if (p_cpo == empty_option)
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7213 p_cpo = save_cpo;
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7214 else
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7215 // Darn, some plugin changed the value.
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7216 free_string_option(save_cpo);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7217
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7218 if (au_name != NULL)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7219 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7220 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7221 curbuf->b_fname, TRUE, curbuf);
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
7222 if (!new_qi && IS_LL_STACK(qi) && qf_find_buf(qi) == NULL)
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7223 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7224 // autocommands made "qi" invalid
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7225 decr_quickfix_busy();
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7226 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7227 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7228 }
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7229
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7230 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
7231 if (!qf_list_empty(qi, qi->qf_curlist))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7232 qf_jump(qi, 0, 0, FALSE);
9
4102fb4ea781 updated for version 7.0002
vimboss
parents: 7
diff changeset
7233 else
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
7234 semsg(_(e_nomatch2), eap->arg);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7235
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7236 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7237
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7238 if (eap->cmdidx == CMD_lhelpgrep)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7239 {
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7240 // If the help window is not opened or if it already points to the
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7241 // correct location list, then free the new location list.
11800
5ceaecedbad2 patch 8.0.0782: using freed memory in quickfix code
Christian Brabandt <cb@256bit.org>
parents: 11788
diff changeset
7242 if (!bt_help(curwin->w_buffer) || curwin->w_llist == qi)
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7243 {
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7244 if (new_qi)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7245 ll_free_all(&qi);
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7246 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7247 else if (curwin->w_llist == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7248 curwin->w_llist = qi;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7249 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7250 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7251
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7252 #endif /* FEAT_QUICKFIX */