annotate src/quickfix.c @ 15639:250b8b1a25ab

Added tag v8.1.0827 for changeset 996e75c90f91f954ffb0e8a4b2290e54c94de455
author Bram Moolenaar <Bram@vim.org>
date Sat, 26 Jan 2019 17:45:13 +0100
parents 639b8318472c
children 2c264fda0f59
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 char_u *line;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3051 colnr_T screen_col;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3052 colnr_T char_col;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3053
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3054 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
3055 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3056 // 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
3057 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
3058 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
3059 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3060 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
3061 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
3062 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
3063 }
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_col > 0)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3065 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3066 curwin->w_cursor.col = qf_col - 1;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3067 #ifdef FEAT_VIRTUALEDIT
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3068 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
3069 #endif
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3070 if (qf_viscol == TRUE)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3071 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3072 // Check each character from the beginning of the error
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3073 // line up to the error column. For each tab character
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3074 // found, reduce the error column value by the length of
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3075 // a tab character.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3076 line = ml_get_curline();
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3077 screen_col = 0;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3078 for (char_col = 0; char_col < curwin->w_cursor.col; ++char_col)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3079 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3080 if (*line == NUL)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3081 break;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3082 if (*line++ == '\t')
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3083 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3084 curwin->w_cursor.col -= 7 - (screen_col % 8);
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3085 screen_col += 8 - (screen_col % 8);
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 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3088 ++screen_col;
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 }
14552
b298737a7188 patch 8.1.0289: cursor moves to wrong column after quickfix jump
Christian Brabandt <cb@256bit.org>
parents: 14550
diff changeset
3091 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
3092 check_cursor();
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3093 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3094 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3095 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
3096 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3097 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3098 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3099 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
3100
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3101 // 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
3102 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
3103 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
3104 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
3105 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
3106 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
3107 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3108 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3109
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3110 /*
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3111 * 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
3112 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3113 static void
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3114 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
3115 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
3116 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
3117 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
3118 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
3119 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
3120 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3121 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
3122 int len;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3123
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3124 // 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
3125 // 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
3126 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
3127 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
3128 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
3129 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
3130 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
3131 (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
3132 // 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
3133 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
3134 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
3135
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3136 // 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
3137 // 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
3138 // 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
3139 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
3140 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
3141 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
3142 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
3143 msg_scroll = FALSE;
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3144 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
3145 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
3146 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3147
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3148 /*
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3149 * 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
3150 * 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
3151 * 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
3152 * 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
3153 * 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
3154 * with the entry.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3155 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3156 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
3157 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
3158 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
3159 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
3160 int newwin,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3161 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
3162 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3163 // 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
3164 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
3165 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
3166 return FAIL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3167
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3168 // 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
3169 // file in.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3170 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
3171 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3172 // 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
3173 // 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
3174 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
3175 return NOTDONE;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3176
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3177 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
3178 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
3179 return FAIL;
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
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3182 return OK;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3183 }
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 /*
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3186 * 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
3187 * 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
3188 * jump.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3189 * 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
3190 * 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
3191 * the file.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3192 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3193 static int
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3194 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
3195 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
3196 int qf_index,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3197 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
3198 int forceit,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3199 win_T *oldwin,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3200 int *opened_window,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3201 int openfold,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3202 int print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3203 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3204 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
3205 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
3206 int retval = OK;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3207
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3208 // 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
3209 // autowrite etc.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3210 old_curbuf = curbuf;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3211 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
3212
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3213 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
3214 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3215 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
3216 opened_window);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3217 if (retval != OK)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3218 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3219 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3220
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3221 // 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
3222 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
3223 setpcmark();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3224
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3225 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
3226 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
3227
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3228 #ifdef FEAT_FOLDING
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3229 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
3230 foldOpenCursor();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3231 #endif
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3232 if (print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3233 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
3234
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3235 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3236 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3237
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3238 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3239 * Jump to a quickfix line and try to use an existing window.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3240 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3241 void
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3242 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
3243 int dir,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3244 int errornr,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3245 int forceit)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3246 {
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3247 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
3248 }
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3249
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3250 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3251 * 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
3252 * 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
3253 * 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
3254 * 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
3255 * 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
3256 * 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
3257 * 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
3258 * 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
3259 * 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
3260 */
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3261 void
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3262 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
3263 int dir,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3264 int errornr,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3265 int forceit,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3266 int newwin)
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3267 {
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
3268 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3269 qfline_T *qf_ptr;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3270 qfline_T *old_qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3271 int qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3272 int old_qf_index;
639
c79d4df4686e updated for version 7.0185
vimboss
parents: 634
diff changeset
3273 char_u *old_swb = p_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3274 unsigned old_swb_flags = swb_flags;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3275 int opened_window = FALSE;
1743
734d5bdae499 updated for version 7.2-041
vimboss
parents: 1683
diff changeset
3276 win_T *oldwin = curwin;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3277 int print_message = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3278 #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
3279 int old_KeyTyped = KeyTyped; // getting file may reset it
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3280 #endif
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3281 int retval = OK;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3282
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3283 if (qi == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3284 qi = &ql_info;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3285
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3286 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3287 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3288 emsg(_(e_quickfix));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3289 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3290 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3291
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
3292 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
3293
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3294 qf_ptr = qfl->qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3295 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
3296 qf_index = qfl->qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3297 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
3298
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3299 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
3300 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
3301 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3302 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
3303 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
3304 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3305 }
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
3306
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3307 qfl->qf_index = qf_index;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3308 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
3309 // 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
3310 // window
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3311 print_message = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3312
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3313 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
3314 if (retval == FAIL)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3315 goto failed;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3316 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3317 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3318
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3319 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
3320 &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
3321 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3322 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3323 // 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
3324 qi = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3325 qf_ptr = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3326 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3327
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3328 if (retval != OK)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3329 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3330 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
3331 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
3332 if (qf_ptr != NULL && qf_ptr->qf_fnum != 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3333 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3334 // 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
3335 // happen if the file was readonly and we changed something.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3336 failed:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3337 qf_ptr = old_qf_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3338 qf_index = old_qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3339 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3340 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3341 theend:
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3342 if (qi != NULL)
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3343 {
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
3344 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
3345 qfl->qf_index = qf_index;
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3346 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3347 if (p_swb != old_swb && opened_window)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3348 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3349 // 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
3350 // modeline has changed the value.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3351 if (p_swb == empty_option)
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3352 {
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3353 p_swb = old_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3354 swb_flags = old_swb_flags;
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3355 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3356 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3357 free_string_option(old_swb);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3358 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3359 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3360
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3361 // 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
3362 static int qfFileAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3363 static int qfSepAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3364 static int qfLineAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3365
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3366 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3367 * 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
3368 * 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
3369 * '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
3370 * quickfix list.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3371 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3372 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
3373 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
3374 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3375 char_u *fname;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3376 buf_T *buf;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3377 int filter_entry;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3378
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3379 fname = NULL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3380 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
3381 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
3382 (char *)qfp->qf_module);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3383 else {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3384 if (qfp->qf_fnum != 0
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3385 && (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
3386 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3387 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
3388 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
3389 fname = gettail(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3390 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3391 if (fname == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3392 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
3393 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3394 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
3395 qf_idx, (char *)fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3396 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3397
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3398 // 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
3399 // 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
3400 // text of the entry.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3401 filter_entry = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3402 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
3403 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
3404 if (filter_entry && fname != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3405 filter_entry &= message_filtered(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3406 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
3407 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
3408 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3409 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
3410 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3411 return;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3412
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3413 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
3414 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
3415
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3416 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
3417 msg_puts_attr(":", qfSepAttr);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3418 if (qfp->qf_lnum == 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3419 IObuff[0] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3420 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
3421 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
3422 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3423 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
3424 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
3425 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
3426 (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
3427 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
3428 msg_puts_attr(":", qfSepAttr);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3429 if (qfp->qf_pattern != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3430 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3431 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
3432 msg_puts((char *)IObuff);
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3433 msg_puts_attr(":", qfSepAttr);
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3434 }
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
3435 msg_puts(" ");
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3436
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3437 // 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
3438 // 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
3439 // with ^^^^.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3440 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
3441 ? 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
3442 IObuff, IOSIZE);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3443 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
3444 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
3445 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3446
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3447 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3448 * ":clist": list all errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3449 * ":llist": list all locations
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3450 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3451 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3452 qf_list(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3453 {
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
3454 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3455 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3456 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3457 int idx1 = 1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3458 int idx2 = -1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3459 char_u *arg = eap->arg;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3460 int plus = FALSE;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3461 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
3462 // recognised errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3463 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3464
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3465 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3466 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3467 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3468 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3469 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3470 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3471 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3472 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3473 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3474
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3475 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3476 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3477 emsg(_(e_quickfix));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3478 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3479 }
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3480 if (*arg == '+')
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3481 {
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3482 ++arg;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3483 plus = TRUE;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3484 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3485 if (!get_list_range(&arg, &idx1, &idx2) || *arg != NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3486 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3487 emsg(_(e_trailing));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3488 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3489 }
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
3490 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
3491 if (plus)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3492 {
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
3493 i = qfl->qf_index;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3494 idx2 = i + idx1;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3495 idx1 = i;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3496 }
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3497 else
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3498 {
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
3499 i = qfl->qf_count;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3500 if (idx1 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3501 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
3502 if (idx2 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3503 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
3504 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3505
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3506 // 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
3507 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
3508
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3509 // 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
3510 // 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
3511 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
3512 if (qfFileAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3513 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
3514 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
3515 if (qfSepAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3516 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
3517 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
3518 if (qfLineAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3519 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
3520
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
3521 if (qfl->qf_nonevalid)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3522 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
3523 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
3524 for (i = 1; !got_int && i <= qfl->qf_count; )
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3525 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3526 if ((qfp->qf_valid || all) && idx1 <= i && i <= idx2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3527 {
2047
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3528 if (got_int)
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3529 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3530
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
3531 qf_list_entry(qfp, i, i == qfl->qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3532 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3533
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3534 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3535 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3536 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3537 ++i;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3538 ui_breakcheck();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3539 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3540 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3541
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3542 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3543 * Remove newlines and leading whitespace from an error message.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3544 * Put the result in "buf[bufsize]".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3545 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3546 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3547 qf_fmt_text(char_u *text, char_u *buf, int bufsize)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3548 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3549 int i;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3550 char_u *p = text;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3551
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3552 for (i = 0; *p != NUL && i < bufsize - 1; ++i)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3553 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3554 if (*p == '\n')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3555 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3556 buf[i] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3557 while (*++p != NUL)
11129
f4ea50924c6d patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents: 11063
diff changeset
3558 if (!VIM_ISWHITE(*p) && *p != '\n')
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3559 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3560 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3561 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3562 buf[i] = *p++;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3563 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3564 buf[i] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3565 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3566
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3567 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3568 * 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
3569 * quickfix/location list.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3570 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3571 static void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3572 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
3573 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3574 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
3575 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
3576 char_u buf[IOSIZE];
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3577
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3578 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
3579 lead,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3580 which + 1,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3581 qi->qf_listcount,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3582 count);
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3583
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3584 if (title != NULL)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3585 {
9579
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3586 size_t len = STRLEN(buf);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3587
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3588 if (len < 34)
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3589 {
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3590 vim_memset(buf + len, ' ', 34 - len);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3591 buf[34] = NUL;
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3592 }
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3593 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
3594 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3595 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
3596 msg((char *)buf);
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3597 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3598
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3599 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3600 * ":colder [count]": Up in the quickfix stack.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3601 * ":cnewer [count]": Down in the quickfix stack.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3602 * ":lolder [count]": Up in the location list stack.
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3603 * ":lnewer [count]": Down in the location list stack.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3604 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3605 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3606 qf_age(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3607 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3608 qf_info_T *qi = &ql_info;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3609 int count;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3610
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3611 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3612 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3613 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3614 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3615 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3616 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3617 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3618 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3619 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3620
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3621 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3622 count = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3623 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3624 count = 1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3625 while (count--)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3626 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3627 if (eap->cmdidx == CMD_colder || eap->cmdidx == CMD_lolder)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3628 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3629 if (qi->qf_curlist == 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3630 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3631 emsg(_("E380: At bottom of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3632 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3633 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3634 --qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3635 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3636 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3637 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3638 if (qi->qf_curlist >= qi->qf_listcount - 1)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3639 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3640 emsg(_("E381: At top of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3641 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3642 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3643 ++qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3644 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3645 }
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3646 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
3647 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3648 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3649
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3650 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3651 * 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
3652 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3653 void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3654 qf_history(exarg_T *eap)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3655 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3656 qf_info_T *qi = &ql_info;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3657 int i;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3658
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3659 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
3660 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
3661 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
3662 msg(_("No entries"));
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3663 else
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3664 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
3665 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
3666 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3667
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3668 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3669 * 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
3670 * associated with the list like context and title are not freed.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3671 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3672 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
3673 qf_free_items(qf_list_T *qfl)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3674 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3675 qfline_T *qfp;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3676 qfline_T *qfpnext;
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3677 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
3678
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 while (qfl->qf_count && qfl->qf_start != NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3680 {
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
3681 qfp = qfl->qf_start;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3682 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
3683 if (!stop)
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3684 {
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
3685 vim_free(qfp->qf_module);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3686 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
3687 vim_free(qfp->qf_pattern);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3688 stop = (qfp == qfpnext);
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3689 vim_free(qfp);
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3690 if (stop)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3691 // 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
3692 // 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
3693 // 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
3694 qfl->qf_count = 1;
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3695 }
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
3696 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
3697 --qfl->qf_count;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3698 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3699
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
3700 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
3701 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
3702 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
3703 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
3704 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
3705
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
3706 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
3707 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
3708 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
3709 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
3710 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
3711 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
3712 qfl->qf_multiscan = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3713 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3714
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3715 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3716 * 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
3717 * 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
3718 */
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3719 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
3720 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
3721 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3722 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
3723
13244
ac42c4b11dbc patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents: 13115
diff changeset
3724 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
3725 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
3726 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
3727 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
3728 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
3729 }
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3730
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3731 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3732 * qf_mark_adjust: adjust marks
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3733 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3734 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3735 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
3736 win_T *wp,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3737 linenr_T line1,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3738 linenr_T line2,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3739 long amount,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3740 long amount_after)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3741 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3742 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3743 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3744 int idx;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3745 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
3746 int found_one = FALSE;
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3747 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
3748
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3749 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
3750 return;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3751 if (wp != NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3752 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3753 if (wp->w_llist == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3754 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3755 qi = wp->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3756 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3757
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3758 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
3759 if (!qf_list_empty(qi, idx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3760 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
3761 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
3762 ++i, qfp = qfp->qf_next)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3763 if (qfp->qf_fnum == curbuf->b_fnum)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3764 {
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3765 found_one = TRUE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3766 if (qfp->qf_lnum >= line1 && qfp->qf_lnum <= line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3767 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3768 if (amount == MAXLNUM)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3769 qfp->qf_cleared = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3770 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3771 qfp->qf_lnum += amount;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3772 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3773 else if (amount_after && qfp->qf_lnum > line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3774 qfp->qf_lnum += amount_after;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3775 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3776
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3777 if (!found_one)
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3778 curbuf->b_has_qf_entry &= ~buf_has_flag;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3779 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3780
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3781 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3782 * Make a nice message out of the error character and the error number:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3783 * char number message
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3784 * e or E 0 " error"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3785 * w or W 0 " warning"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3786 * i or I 0 " info"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3787 * 0 0 ""
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3788 * other 0 " c"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3789 * e or E n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3790 * w or W n " warning n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3791 * i or I n " info n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3792 * 0 n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3793 * other n " c n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3794 * 1 x "" :helpgrep
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3795 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3796 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3797 qf_types(int c, int nr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3798 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3799 static char_u buf[20];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3800 static char_u cc[3];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3801 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3802
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3803 if (c == 'W' || c == 'w')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3804 p = (char_u *)" warning";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3805 else if (c == 'I' || c == 'i')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3806 p = (char_u *)" info";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3807 else if (c == 'E' || c == 'e' || (c == 0 && nr > 0))
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3808 p = (char_u *)" error";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3809 else if (c == 0 || c == 1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3810 p = (char_u *)"";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3811 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3812 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3813 cc[0] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3814 cc[1] = c;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3815 cc[2] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3816 p = cc;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3817 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3818
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3819 if (nr <= 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3820 return p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3821
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3822 sprintf((char *)buf, "%s %3d", (char *)p, nr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3823 return buf;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3824 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3825
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3826 /*
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
3827 * 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
3828 * 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
3829 */
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 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
3831 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
3832 {
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 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
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 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
3836 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
3837
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
3838 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
3839 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
3840
14491
9df0fcbfebb2 patch 8.1.0259: no test for fixed quickfix issue
Christian Brabandt <cb@256bit.org>
parents: 14477
diff changeset
3841 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
3842 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
3843 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
3844 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
3845 }
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
3846
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
3847 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
3848 {
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3849 // 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
3850 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
3851 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
3852 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
3853 }
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
3854
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
3855 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
3856 }
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
3857
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
3858 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3859 * ":cwindow": open the quickfix window if we have errors to display,
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3860 * close it if not.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3861 * ":lwindow": open the location list window if we have locations to display,
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3862 * close it if not.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3863 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3864 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3865 ex_cwindow(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3866 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3867 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
3868 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3869 win_T *win;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3870
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3871 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3872 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3873 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3874 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3875 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3876 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3877
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
3878 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
3879
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3880 // Look for an existing quickfix window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3881 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3882
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3883 // 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
3884 // 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
3885 // 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
3886 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
3887 || 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
3888 || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3889 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3890 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3891 ex_cclose(eap);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3892 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3893 else if (win == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3894 ex_copen(eap);
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 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3898 * ":cclose": close the window showing the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3899 * ":lclose": close the window showing the location list
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3900 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3901 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3902 ex_cclose(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3903 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3904 win_T *win = NULL;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3905 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3906
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3907 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3908 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3909 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3910 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3911 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3912 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3913
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3914 // Find existing quickfix window and close it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3915 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3916 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3917 win_close(win, FALSE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3918 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3919
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3920 /*
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
3921 * 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
3922 */
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3923 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
3924 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
3925 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3926 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
3927 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
3928 }
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3929
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3930 /*
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3931 * 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
3932 * 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
3933 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3934 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3935 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
3936 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3937 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3938
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3939 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
3940 if (win == NULL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3941 return FAIL;
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 win_goto(win);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3944 if (resize)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3945 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3946 if (vertsplit)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3947 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3948 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
3949 win_setwidth(sz);
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 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
3952 win_setheight(sz);
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
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3955 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3956 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3957
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3958 /*
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3959 * 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
3960 * 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
3961 * 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
3962 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3963 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3964 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
3965 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3966 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
3967 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
3968 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
3969 int flags = 0;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3970 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3971
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3972 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
3973
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3974 // 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
3975 win = curwin;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3976
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3977 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
3978 // 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
3979 // :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
3980 win_goto(lastwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3981 // 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
3982 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
3983 flags = WSP_BELOW;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3984 flags |= WSP_NEWLOC;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3985 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
3986 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
3987 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3988
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3989 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
3990 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3991 // 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
3992 // 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
3993 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
3994 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
3995 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3996
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3997 if (oldwin != curwin)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3998 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
3999 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
4000 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4001 // 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
4002 (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
4003 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
4004 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4005 else
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4006 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4007 // 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
4008 (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
4009
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4010 // switch off 'swapfile'
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4011 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
4012 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
4013 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4014 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
4015 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4016 #ifdef FEAT_DIFF
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4017 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
4018 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4019 #ifdef FEAT_FOLDING
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4020 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
4021 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4022 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4023 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4024
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4025 // 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
4026 // 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
4027 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
4028 win_setheight(height);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4029 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
4030 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
4031 prevwin = win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4032
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4033 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4034 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4035
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4036 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4037 * ":copen": open a window that shows the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4038 * ":lopen": open a window that shows the location list.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4039 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4040 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4041 ex_copen(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4042 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4043 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
4044 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4045 int height;
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4046 int status = FAIL;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4047 int lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4048
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4049 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4050 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4051 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4052 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4053 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4054 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4055 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4056 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4057 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4058
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4059 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4060
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4061 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4062 height = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4063 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4064 height = QF_WINHEIGHT;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4065
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4066 reset_VIsual_and_resel(); // stop Visual mode
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4067 #ifdef FEAT_GUI
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4068 need_mouse_correct = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4069 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4070
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4071 // 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
4072 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
4073 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
4074 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
4075 if (status == FAIL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4076 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
4077 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4078 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
4079 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4080 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4081
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4082 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
4083 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
4084 // 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
4085 // the quickfix list
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4086 lnum = qfl->qf_index;
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4087
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4088 // 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
4089 qf_fill_buffer(qi, curbuf, NULL);
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4090
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4091 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4092
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4093 curwin->w_cursor.lnum = lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4094 curwin->w_cursor.col = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4095 check_cursor();
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4096 update_topline(); // scroll to show the line
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4097 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4098
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4099 /*
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4100 * 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
4101 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4102 static void
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4103 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
4104 {
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4105 win_T *old_curwin = curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4106
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4107 curwin = win;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4108 curbuf = win->w_buffer;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4109 curwin->w_cursor.lnum = lnum;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4110 curwin->w_cursor.col = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4111 #ifdef FEAT_VIRTUALEDIT
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4112 curwin->w_cursor.coladd = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4113 #endif
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4114 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
4115 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
4116 redraw_later(VALID);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4117 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
4118 curwin = old_curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4119 curbuf = curwin->w_buffer;
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
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4122 /*
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4123 * :cbottom/:lbottom commands.
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4124 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4125 void
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4126 ex_cbottom(exarg_T *eap)
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4127 {
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4128 qf_info_T *qi = &ql_info;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4129 win_T *win;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4130
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4131 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
4132 {
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4133 qi = GET_LOC_LIST(curwin);
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4134 if (qi == NULL)
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4135 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4136 emsg(_(e_loclist));
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4137 return;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4138 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4139 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4140
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4141 win = qf_find_win(qi);
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4142 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
4143 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
4144 }
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4145
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4146 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4147 * Return the number of the current entry (line number in the quickfix
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4148 * window).
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4149 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4150 linenr_T
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4151 qf_current_entry(win_T *wp)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4152 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4153 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4154
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4155 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
4156 // In the location list window, use the referenced location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4157 qi = wp->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4158
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4159 return qi->qf_lists[qi->qf_curlist].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
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4162 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4163 * Update the cursor position in the quickfix window to the current error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4164 * Return TRUE if there is a quickfix window.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4165 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4166 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4167 qf_win_pos_update(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4168 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
4169 int old_qf_index) // previous qf_index or zero
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4170 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4171 win_T *win;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4172 int qf_index = qi->qf_lists[qi->qf_curlist].qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4173
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4174 // 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
4175 // it's viewable.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4176 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4177 if (win != NULL
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4178 && qf_index <= win->w_buffer->b_ml.ml_line_count
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4179 && old_qf_index != qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4180 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4181 if (qf_index > old_qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4182 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4183 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
4184 win->w_redraw_bot = qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4185 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4186 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4187 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4188 win->w_redraw_top = qf_index;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4189 win->w_redraw_bot = old_qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4190 }
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4191 qf_win_goto(win, qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4192 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4193 return win != NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4194 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4195
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4196 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4197 * 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
4198 * stack.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4199 */
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4200 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4201 is_qf_win(win_T *win, qf_info_T *qi)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4202 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4203 // 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
4204 // set to NULL.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4205 // 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
4206 // pointing to the location list.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4207 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
4208 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
4209 || (IS_LL_STACK(qi) && win->w_llist_ref == qi))
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4210 return TRUE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4211
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4212 return FALSE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4213 }
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4214
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4215 /*
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
4216 * 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
4217 * Only searches in the current tabpage.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4218 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4219 static win_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4220 qf_find_win(qf_info_T *qi)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4221 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4222 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4223
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4224 FOR_ALL_WINDOWS(win)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4225 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
4226 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
4227 return NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4228 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4229
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4230 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4231 * Find a quickfix buffer.
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4232 * Searches in windows opened in all the tabs.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4233 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4234 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4235 qf_find_buf(qf_info_T *qi)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4236 {
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4237 tabpage_T *tp;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4238 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4239
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4240 FOR_ALL_TAB_WINDOWS(tp, win)
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4241 if (is_qf_win(win, qi))
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4242 return win->w_buffer;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4243
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4244 return NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4245 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4246
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4247 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4248 * 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
4249 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4250 static void
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4251 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
4252 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4253 win_T *win;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4254 win_T *curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4255
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4256 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
4257 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4258 curwin_save = curwin;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4259 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
4260 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
4261 curwin = curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4262 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4263 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4264
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4265 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4266 * Find the quickfix buffer. If it exists, update the contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4267 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4268 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4269 qf_update_buffer(qf_info_T *qi, qfline_T *old_last)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4270 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4271 buf_T *buf;
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4272 win_T *win;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4273 aco_save_T aco;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4274
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4275 // Check if a buffer for the quickfix list exists. Update it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4276 buf = qf_find_buf(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4277 if (buf != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4278 {
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4279 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
4280
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4281 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
4282 // 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
4283 aucmd_prepbuf(&aco, buf);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4284
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4285 qf_update_win_titlevar(qi);
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4286
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4287 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
4288 ++CHANGEDTICK(buf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4289
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4290 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4291 {
8932
25c2031e9f9f commit https://github.com/vim/vim/commit/c1808d5822ed9534ef7f0fe509b15bee92a5cc28
Christian Brabandt <cb@256bit.org>
parents: 8751
diff changeset
4292 (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
4293
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4294 // 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
4295 aucmd_restbuf(&aco);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4296 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
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 // 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
4299 // 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
4300 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
4301 redraw_buf_later(buf, NOT_VALID);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4302 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4303 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4304
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4305 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4306 * 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
4307 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4308 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4309 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
4310 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4311 int len;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4312 buf_T *errbuf;
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 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
4315 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4316 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
4317 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4318 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4319 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
4320 && (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
4321 && errbuf->b_fname != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4322 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4323 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
4324 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
4325 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4326 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4327 // 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
4328 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
4329 || 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
4330 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4331 if (*dirname == NUL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4332 mch_dirname(dirname, MAXPATHL);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4333 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
4334 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4335 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
4336 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4337 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4338 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4339 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4340 len = 0;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4341 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4342
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4343 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
4344 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4345 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
4346 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
4347
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4348 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
4349 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4350 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
4351 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
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 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
4355 (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
4356 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
4357 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4358 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
4359 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4360 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
4361 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
4362 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4363 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4364 IObuff[len++] = ' ';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4365
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4366 // 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
4367 // 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
4368 // 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
4369 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
4370 IObuff + len, IOSIZE - len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4371
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4372 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
4373 (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
4374 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4375
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4376 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4377 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4378
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4379 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4380 * Fill current buffer with quickfix errors, replacing any previous contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4381 * 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
4382 * 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
4383 * 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
4384 * ml_delete() is used and autocommands will be triggered.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4385 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4386 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4387 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
4388 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4389 linenr_T lnum;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4390 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4391 int old_KeyTyped = KeyTyped;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4392
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4393 if (old_last == NULL)
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 if (buf != curbuf)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4396 {
10359
66f1b5bf3fa6 commit https://github.com/vim/vim/commit/95f096030ed1a8afea028f2ea295d6f6a70f466f
Christian Brabandt <cb@256bit.org>
parents: 10349
diff changeset
4397 internal_error("qf_fill_buffer()");
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4398 return;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4399 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4400
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4401 // delete all existing lines
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4402 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
4403 (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
4404 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4405
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4406 // 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
4407 if (!qf_stack_empty(qi))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4408 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4409 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
4410 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
4411
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4412 *dirname = NUL;
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4413
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4414 // 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
4415 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4416 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4417 qfp = qfl->qf_start;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4418 lnum = 0;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4419 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4420 else
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4421 {
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4422 qfp = old_last->qf_next;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4423 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
4424 }
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4425 while (lnum < qfl->qf_count)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4426 {
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4427 if (qf_buf_add_line(buf, lnum, qfp, dirname) == FAIL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4428 break;
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4429
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4430 ++lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4431 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4432 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4433 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4434 }
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4435
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4436 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
4437 // 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
4438 (void)ml_delete(lnum + 1, FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4439 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4440
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4441 // correct cursor position
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4442 check_lnums(TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4443
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4444 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4445 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4446 // 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
4447 // 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
4448 // using autocommands.
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4449 ++curbuf_lock;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4450 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
4451 curbuf->b_p_ma = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4452
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4453 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
4454 apply_autocmds(EVENT_BUFREADPOST, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4455 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4456 apply_autocmds(EVENT_BUFWINENTER, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4457 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4458 keep_filetype = FALSE;
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4459 --curbuf_lock;
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
4460
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4461 // 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
4462 redraw_curbuf_later(NOT_VALID);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4463 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4464
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4465 // Restore KeyTyped, setting 'filetype' may reset it.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4466 KeyTyped = old_KeyTyped;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4467 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4468
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4469 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4470 * 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
4471 */
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4472 static void
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4473 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
4474 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4475 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
4476 }
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4477
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4478 /*
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4479 * 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
4480 * 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
4481 */
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4482 static int
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4483 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
4484 {
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4485 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
4486
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4487 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
4488 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
4489 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
4490 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
4491 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4492
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4493 /*
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4494 * 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
4495 * 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
4496 * 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
4497 * 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
4498 * 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
4499 */
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4500 static int
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4501 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
4502 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4503 int curlist;
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4504
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4505 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
4506 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4507 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
4508 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
4509 // 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
4510 return FAIL;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4511 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
4512 }
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4513 return OK;
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4514 }
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4515
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4516 /*
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4517 * 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
4518 */
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4519 static void
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4520 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
4521 {
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4522 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
4523 return;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4524
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4525 // 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
4526 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
4527 qf_jump(qi, 0, 0, forceit);
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4528 }
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4529
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4530 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4531 * Return TRUE when using ":vimgrep" for ":grep".
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4532 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4533 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4534 grep_internal(cmdidx_T cmdidx)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4535 {
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4536 return ((cmdidx == CMD_grep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4537 || cmdidx == CMD_lgrep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4538 || cmdidx == CMD_grepadd
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4539 || cmdidx == CMD_lgrepadd)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4540 && STRCMP("internal",
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4541 *curbuf->b_p_gp == NUL ? p_gp : curbuf->b_p_gp) == 0);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4542 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4543
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4544 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4545 * 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
4546 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4547 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4548 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
4549 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4550 switch (cmdidx)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4551 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4552 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
4553 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
4554 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
4555 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
4556 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
4557 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
4558 default: return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4559 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4560 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4561
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4562 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4563 * Return the name for the errorfile, in allocated memory.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4564 * Find a new unique name when 'makeef' contains "##".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4565 * Returns NULL for error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4566 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4567 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4568 get_mef_name(void)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4569 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4570 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4571 char_u *name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4572 static int start = -1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4573 static int off = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4574 #ifdef HAVE_LSTAT
9387
f094d4085014 commit https://github.com/vim/vim/commit/8767f52fbfd4f053ce00a978227c95f1d7d323fe
Christian Brabandt <cb@256bit.org>
parents: 9379
diff changeset
4575 stat_T sb;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4576 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4577
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4578 if (*p_mef == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4579 {
6721
7347229a646a updated for version 7.4.684
Bram Moolenaar <bram@vim.org>
parents: 6450
diff changeset
4580 name = vim_tempname('e', FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4581 if (name == NULL)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4582 emsg(_(e_notmp));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4583 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4584 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4585
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4586 for (p = p_mef; *p; ++p)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4587 if (p[0] == '#' && p[1] == '#')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4588 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4589
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4590 if (*p == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4591 return vim_strsave(p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4592
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4593 // Keep trying until the name doesn't exist yet.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4594 for (;;)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4595 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4596 if (start == -1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4597 start = mch_get_pid();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4598 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4599 off += 19;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4600
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4601 name = alloc((unsigned)STRLEN(p_mef) + 30);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4602 if (name == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4603 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4604 STRCPY(name, p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4605 sprintf((char *)name + (p - p_mef), "%d%d", start, off);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4606 STRCAT(name, p + 2);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4607 if (mch_getperm(name) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4608 #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
4609 // Don't accept a symbolic link, it's a security risk.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4610 && mch_lstat((char *)name, &sb) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4611 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4612 )
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4613 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4614 vim_free(name);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4615 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4616 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4617 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4618
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4619 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4620 * 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
4621 * 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
4622 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4623 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4624 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
4625 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4626 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4627 unsigned len;
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 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
4630 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
4631 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
4632 cmd = alloc(len);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4633 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4634 return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4635 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
4636 (char *)p_shq);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4637
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4638 // 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
4639 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
4640 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
4641
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4642 // 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
4643 // 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
4644 // in column 0).
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4645 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
4646 msg_didout = FALSE;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4647 msg_start();
15543
dd725a8ab112 patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents: 15490
diff changeset
4648 msg_puts(":!");
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4649 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
4650
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4651 return cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4652 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4653
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 * 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
4656 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4657 void
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4658 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
4659 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4660 char_u *fname;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4661 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4662 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
4663 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
4664 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
4665 int res;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4666 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
4667 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
4668
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4669 // 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
4670 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
4671 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4672 ex_vimgrep(eap);
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
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4676 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
4677 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
4678 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
4679 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4680 #ifdef FEAT_EVAL
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4681 if (aborting())
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4682 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4683 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4684 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4685 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
4686
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4687 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
4688 wp = curwin;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4689
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4690 autowrite_all();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4691 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
4692 if (fname == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4693 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4694 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
4695
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4696 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
4697 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4698 return;
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 // 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
4701 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
4702
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4703 #ifdef AMIGA
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4704 out_flush();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4705 // 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
4706 (void)char_avail();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4707 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4708
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4709 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4710
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4711 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
4712 && 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
4713 (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
4714 && 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
4715 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
4716 if (wp != NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4717 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4718 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
4719 if (qi == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4720 goto cleanup;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4721 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4722 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4723 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
4724
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4725 // 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
4726 // 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
4727 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
4728 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
4729 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
4730 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
4731 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
4732 // 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
4733 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
4734
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4735 cleanup:
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4736 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
4737 mch_remove(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4738 vim_free(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4739 vim_free(cmd);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4740 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4741
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4742 /*
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4743 * 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
4744 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4745 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4746 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
4747 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4748 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
4749 qf_list_T *qfl;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4750 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4751 int i, sz = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4752 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4753
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4754 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
4755 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4756 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4757 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4758 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4759 return 0;
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
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4762 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
4763 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
4764 ++i, qfp = qfp->qf_next)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4765 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4766 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4767 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4768 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
4769 sz++; // Count all valid entries
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4770 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
4771 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4772 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4773 sz++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4774 prev_fnum = qfp->qf_fnum;
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
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4779 return sz;
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
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4782 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4783 * 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
4784 * 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
4785 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4786 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4787 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
4788 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4789 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4790
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4791 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
4792 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4793 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4794 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4795 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4796 return 0;
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
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4799 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
4800 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4801
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4802 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4803 * 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
4804 * 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
4805 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4806 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4807 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
4808 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4809 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4810 qf_list_T *qfl;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4811 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4812 int i, eidx = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4813 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4814
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4815 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
4816 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4817 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4818 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4819 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4820 return 1;
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 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
4824 qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4825
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4826 // 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
4827 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
4828 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4829
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4830 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
4831 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4832 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4833 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4834 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
4835 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4836 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
4837 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4838 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4839 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4840 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4841 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4842 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4843 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4844 eidx++;
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 }
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 return eidx ? eidx : 1;
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
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4851 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4852 * 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
4853 * 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
4854 * 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
4855 * 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
4856 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4857 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
4858 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
4859 {
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4860 qfline_T *qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4861 int i, eidx;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4862 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4863
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4864 // 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
4865 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
4866 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4867
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4868 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
4869 i++, qfp = qfp->qf_next)
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 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4872 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4873 if (fdo)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4874 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4875 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
4876 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4877 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4878 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4879 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4880 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4881 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4882 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4883 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4884 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4885
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4886 if (eidx == n)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4887 break;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4888 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4889
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4890 if (i <= qfl->qf_count)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4891 return i;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4892 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4893 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4894 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4895
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4896 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4897 * ":cc", ":crewind", ":cfirst" and ":clast".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4898 * ":ll", ":lrewind", ":lfirst" and ":llast".
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4899 * ":cdo", ":ldo", ":cfdo" and ":lfdo"
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4900 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4901 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4902 ex_cc(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4903 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4904 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
4905 int errornr;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4906
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4907 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4908 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4909 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4910 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4911 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4912 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4913 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4914 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4915 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4916
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4917 if (eap->addr_count > 0)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4918 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4919 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4920 {
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4921 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4922 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4923 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
4924 errornr = 0;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4925 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4926 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
4927 case CMD_lfirst:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4928 errornr = 1;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4929 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4930 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4931 errornr = 32767;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4932 }
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4933 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4934
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4935 // 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
4936 // 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
4937 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
4938 || 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
4939 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
4940 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
4941 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
4942
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4943 qf_jump(qi, 0, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4944 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4945
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4946 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4947 * ":cnext", ":cnfile", ":cNext" and ":cprevious".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4948 * ":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
4949 * Also, used by ":cdo", ":ldo", ":cfdo" and ":lfdo" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4950 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4951 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4952 ex_cnext(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4953 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4954 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
4955 int errornr;
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4956 int dir;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4957
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4958 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4959 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4960 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4961 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4962 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
4963 emsg(_(e_loclist));
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4964 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4965 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4966 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4967
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
4968 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
4969 && (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
4970 && 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
4971 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4972 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4973 errornr = 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4974
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4975 // 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
4976 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4977 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4978 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
4979 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4980 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4981 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
4982 case CMD_lNext:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4983 dir = BACKWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4984 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4985 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
4986 dir = FORWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4987 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4988 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
4989 dir = BACKWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4990 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4991 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4992 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4993 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4994 }
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4995
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4996 qf_jump(qi, dir, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4997 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4998
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4999 /*
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
5000 * ":cfile"/":cgetfile"/":caddfile" commands.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
5001 * ":lfile"/":lgetfile"/":laddfile" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5002 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5003 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5004 ex_cfile(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5005 {
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
5006 char_u *enc = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
5007 win_T *wp = NULL;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
5008 qf_info_T *qi = &ql_info;
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5009 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
5010 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
5011 int res;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
5012
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5013 switch (eap->cmdidx)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5014 {
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5015 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
5016 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
5017 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
5018 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
5019 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
5020 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
5021 default: break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5022 }
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5023 if (au_name != NULL)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5024 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
5025 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
5026 #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
5027 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
5028 {
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5029 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
5030 NULL, NULL,
378f9f8e6d8f patch 8.0.1773: dialog messages are not translated
Christian Brabandt <cb@256bit.org>
parents: 13800
diff changeset
5031 (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
5032 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
5033 return;
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5034 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
5035 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
5036 }
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5037 else
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5038 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5039 if (*eap->arg != NUL)
694
07d199fe02ed updated for version 7.0209
vimboss
parents: 682
diff changeset
5040 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
5041
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5042 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
5043 wp = curwin;
a1f8939a4644 patch 8.0.1414: accessing freed memory in :lfile.
Christian Brabandt <cb@256bit.org>
parents: 13076
diff changeset
5044
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5045 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5046
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5047 // 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
5048 // commands.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5049 // :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
5050 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5051 // :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
5052 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5053 // :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
5054 // 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
5055 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
5056 && 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
5057 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
5058 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
5059 {
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5060 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
5061 if (qi == NULL)
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5062 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5063 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
5064 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5065 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5066 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5067 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5068 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
5069 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
5070 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
5071 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
5072
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5073 // 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
5074 // 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
5075 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
5076 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5077 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5078 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
5079
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5080 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
5081 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5082
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5083 /*
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5084 * 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
5085 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5086 static char_u *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5087 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
5088 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5089 switch (cmdidx)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5090 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5091 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
5092 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
5093 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
5094 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
5095 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
5096 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
5097 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
5098 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
5099 default: return NULL;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5100 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5101 }
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 * 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
5105 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5106 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5107 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
5108 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5109 // 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
5110 regmatch->regprog = NULL;
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 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
5113 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5114 // 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
5115 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
5116 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5117 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
5118 return;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5119 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5120 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
5121 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5122 else
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5123 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
5124
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5125 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
5126 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
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 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5130 * 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
5131 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5132 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5133 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
5134 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5135 char_u *p;
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 msg_start();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5138 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
5139 if (p == NULL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5140 msg_outtrans(fname);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5141 else
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 msg_outtrans(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5144 vim_free(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5145 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5146 msg_clr_eos();
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5147 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
5148 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
5149 msg_col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5150 out_flush();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5151 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5152
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5153 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5154 * 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
5155 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5156 static buf_T *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5157 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
5158 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5159 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
5160 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
5161 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5162 int save_mls;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5163 #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
5164 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
5165 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5166 buf_T *buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5167
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5168 #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
5169 // 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
5170 // 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
5171 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
5172 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5173 // 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
5174 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
5175 p_mls = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5176
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5177 // 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
5178 // 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
5179 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
5180
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5181 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
5182 #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
5183 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
5184 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5185
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5186 return buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5187 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5188
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5189 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5190 * 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
5191 * 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
5192 * new list.
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5193 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5194 static int
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5195 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
5196 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
5197 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
5198 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
5199 char_u *title)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5200 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5201 // 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
5202 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
5203 {
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5204 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
5205 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5206 // 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
5207 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
5208 return FALSE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5209 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5210 else
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5211 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5212 // 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
5213 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
5214 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
5215 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5216 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5217
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
5218 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
5219 return FALSE;
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5220
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5221 return TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5222 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5223
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5224 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5225 * 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
5226 * 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
5227 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5228 static int
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5229 vgr_match_buflines(
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5230 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
5231 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5232 buf_T *buf,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5233 regmmatch_T *regmatch,
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5234 long *tomatch,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5235 int duplicate_name,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5236 int flags)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5237 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5238 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
5239 long lnum;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5240 colnr_T col;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5241
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5242 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
5243 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5244 col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5245 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
5246 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
5247 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5248 // 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
5249 // 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
5250 // 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
5251 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
5252 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5253 NULL, // dir
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5254 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
5255 NULL,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5256 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
5257 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
5258 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
5259 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
5260 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
5261 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5262 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5263 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5264 0, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5265 TRUE // valid
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5266 ) == FAIL)
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 got_int = TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5269 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5270 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5271 found_match = TRUE;
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5272 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
5273 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5274 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
5275 || 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
5276 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5277 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
5278 + (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
5279 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
5280 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5281 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5282 line_breakcheck();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5283 if (got_int)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5284 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5285 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5286
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5287 return found_match;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5288 }
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 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5291 * 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
5292 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5293 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5294 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
5295 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
5296 int forceit,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5297 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
5298 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
5299 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
5300 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5301 buf_T *buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5302
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5303 buf = curbuf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5304 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
5305 if (buf != curbuf)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5306 // 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
5307 // 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
5308 *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
5309
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5310 // 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
5311 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
5312 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5313 exarg_T ea;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5314
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5315 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
5316 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
5317 ex_cd(&ea);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5318 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5319 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5320
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5321 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5322 * ":vimgrep {pattern} file(s)"
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5323 * ":vimgrepadd {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5324 * ":lvimgrep {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5325 * ":lvimgrepadd {pattern} file(s)"
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5326 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5327 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5328 ex_vimgrep(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5329 {
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5330 regmmatch_T regmatch;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5331 int fcount;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5332 char_u **fnames;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5333 char_u *fname;
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5334 char_u *title;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5335 char_u *s;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5336 char_u *p;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5337 int fi;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5338 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
5339 qf_list_T *qfl;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5340 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
5341 win_T *wp = NULL;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5342 buf_T *buf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5343 int duplicate_name = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5344 int using_dummy;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5345 int redraw_for_dummy = FALSE;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5346 int found_match;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5347 buf_T *first_match_buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5348 time_t seconds = 0;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5349 aco_save_T aco;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5350 int flags = 0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5351 long tomatch;
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5352 char_u *dirname_start = NULL;
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5353 char_u *dirname_now = NULL;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5354 char_u *target_dir = NULL;
1683
75dbeedddaa9 updated for version 7.2b-016
vimboss
parents: 1672
diff changeset
5355 char_u *au_name = NULL;
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5356
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5357 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
5358 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
5359 curbuf->b_fname, TRUE, curbuf))
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5360 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5361 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
5362 if (aborting())
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5363 return;
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5364 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5365 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5366
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5367 if (is_loclist_cmd(eap->cmdidx))
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5368 {
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5369 qi = ll_get_or_alloc_list(curwin);
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5370 if (qi == NULL)
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5371 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
5372 wp = curwin;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5373 }
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5374
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5375 if (eap->addr_count > 0)
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5376 tomatch = eap->line2;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5377 else
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5378 tomatch = MAXLNUM;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5379
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5380 // Get the search pattern: either white-separated or enclosed in //
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5381 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
5382 title = vim_strsave(qf_cmdtitle(*eap->cmdlinep));
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5383 p = skip_vimgrep_pat(eap->arg, &s, &flags);
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5384 if (p == NULL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5385 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5386 emsg(_(e_invalpat));
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5387 goto theend;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5388 }
4197
07fef68eb018 updated for version 7.3.850
Bram Moolenaar <bram@vim.org>
parents: 4003
diff changeset
5389
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5390 vgr_init_regmatch(&regmatch, s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5391 if (regmatch.regprog == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5392 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5393
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5394 p = skipwhite(p);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5395 if (*p == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5396 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5397 emsg(_("E683: File name missing or invalid pattern"));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5398 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5399 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5400
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
5401 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
5402 && 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
5403 && 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
5404 || 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
5405 // 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
5406 qf_new_list(qi, title != NULL ? title : qf_cmdtitle(*eap->cmdlinep));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5407
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5408 // parse the list of arguments
3620
4f1c511e71f8 updated for version 7.3.570
Bram Moolenaar <bram@vim.org>
parents: 3555
diff changeset
5409 if (get_arglist_exp(p, &fcount, &fnames, TRUE) == FAIL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5410 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5411 if (fcount == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5412 {
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5413 emsg(_(e_nomatch));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5414 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5415 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5416
7558
9a4c9dccd603 commit https://github.com/vim/vim/commit/b86a343280b08d6701da68ee0651e960a0a7a61c
Christian Brabandt <cb@256bit.org>
parents: 7515
diff changeset
5417 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
5418 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
5419 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
5420 {
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5421 FreeWild(fcount, fnames);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5422 goto theend;
7662
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5423 }
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
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 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
5426 // ":lcd %:p:h" changes the meaning of short path names.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5427 mch_dirname(dirname_start, MAXPATHL);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5428
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5429 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5430
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5431 // 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
5432 // 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
5433 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
5434
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5435 seconds = (time_t)0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5436 for (fi = 0; fi < fcount && !got_int && tomatch > 0; ++fi)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5437 {
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5438 fname = shorten_fname1(fnames[fi]);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5439 if (time(NULL) > seconds)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5440 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5441 // 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
5442 // working on it.
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5443 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
5444 vgr_display_fname(fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5445 }
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5446
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5447 buf = buflist_findname_exp(fnames[fi]);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5448 if (buf == NULL || buf->b_ml.ml_mfp == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5449 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5450 // Remember that a buffer with this name already exists.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5451 duplicate_name = (buf != NULL);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5452 using_dummy = TRUE;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5453 redraw_for_dummy = TRUE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5454
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5455 buf = vgr_load_dummy_buf(fname, dirname_start, dirname_now);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5456 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5457 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5458 // Use existing, loaded buffer.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5459 using_dummy = FALSE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5460
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5461 // 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
5462 // 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
5463 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
5464 {
2d94fcb0277d patch 8.0.1702: leaking memory when autocommands make quickfix list invalid
Christian Brabandt <cb@256bit.org>
parents: 13612
diff changeset
5465 FreeWild(fcount, fnames);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5466 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
5467 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
5468 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5469 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
5470
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5471 if (buf == NULL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5472 {
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5473 if (!got_int)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5474 smsg(_("Cannot open file \"%s\""), fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5475 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5476 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5477 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5478 // 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
5479 // 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
5480 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
5481 &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
5482
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5483 if (using_dummy)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5484 {
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5485 if (found_match && first_match_buf == NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5486 first_match_buf = buf;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5487 if (duplicate_name)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5488 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5489 // 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
5490 // with the same name.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5491 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5492 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5493 }
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5494 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
5495 || 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
5496 || 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
5497 || buf->b_p_bh[0] == 'd') // "delete"
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
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 // 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
5500 // 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
5501 // 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
5502 // unload the buffer.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5503 // 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
5504 // many swap files.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5505 if (!found_match)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5506 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5507 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5508 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5509 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5510 else if (buf != first_match_buf || (flags & VGR_NOJUMP))
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5511 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5512 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
5513 // 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
5514 buf->b_flags &= ~BF_DUMMY;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5515 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5516 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5517 }
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5518
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5519 if (buf != NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5520 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5521 // 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
5522 buf->b_flags &= ~BF_DUMMY;
64a791c53418 commit https://github.com/vim/vim/commit/015102e91e978a0bb42a14461c132a85e8f7e1ea
Christian Brabandt <cb@256bit.org>
parents: 9538
diff changeset
5523
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5524 // 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
5525 // directory we jumped to below.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5526 if (buf == first_match_buf
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5527 && target_dir == NULL
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5528 && STRCMP(dirname_start, dirname_now) != 0)
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5529 target_dir = vim_strsave(dirname_now);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5530
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5531 // 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
5532 // 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
5533 // 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
5534 // options!
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5535 aucmd_prepbuf(&aco, buf);
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5536 #if defined(FEAT_SYN_HL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5537 apply_autocmds(EVENT_FILETYPE, buf->b_p_ft,
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5538 buf->b_fname, TRUE, buf);
677
e649c78407e6 updated for version 7.0202
vimboss
parents: 665
diff changeset
5539 #endif
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5540 do_modelines(OPT_NOWIN);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5541 aucmd_restbuf(&aco);
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5542 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5543 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5544 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5545 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5546
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5547 FreeWild(fcount, fnames);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5548
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5549 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
5550 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5551 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
5552 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5553 qf_list_changed(qfl);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5554
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
5555 qf_update_buffer(qi, NULL);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5556
842
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5557 if (au_name != NULL)
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5558 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5559 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
5560 // 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
5561 // is still valid.
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5562 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
5563 || 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
5564 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5565 decr_quickfix_busy();
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5566 goto theend;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5567 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5568
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
5569 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5570 if (!qf_list_empty(qi, qi->qf_curlist))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5571 {
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5572 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
5573 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
5574 first_match_buf, target_dir);
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5575 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5576 else
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
5577 semsg(_(e_nomatch2), s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5578
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5579 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5580
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5581 // 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
5582 // may have messed up things, need to redraw and recompute folds.
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5583 if (redraw_for_dummy)
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5584 {
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5585 #ifdef FEAT_FOLDING
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5586 foldUpdateAll(curwin);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5587 #else
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5588 redraw_later(NOT_VALID);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5589 #endif
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5590 }
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5591
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5592 theend:
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5593 vim_free(title);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5594 vim_free(dirname_now);
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5595 vim_free(dirname_start);
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5596 vim_free(target_dir);
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
5597 vim_regfree(regmatch.regprog);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5598 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5599
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5600 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5601 * 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
5602 * 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
5603 */
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5604 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5605 restore_start_dir(char_u *dirname_start)
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5606 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5607 char_u *dirname_now = alloc(MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5608
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5609 if (NULL != dirname_now)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5610 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5611 mch_dirname(dirname_now, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5612 if (STRCMP(dirname_start, dirname_now) != 0)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5613 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5614 // 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
5615 // appropriate ex command and executing it.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5616 exarg_T ea;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5617
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5618 ea.arg = dirname_start;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5619 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
5620 ex_cd(&ea);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5621 }
3974
4d1753f3e85c updated for version 7.3.742
Bram Moolenaar <bram@vim.org>
parents: 3965
diff changeset
5622 vim_free(dirname_now);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5623 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5624 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5625
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5626 /*
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5627 * 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
5628 * 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
5629 * "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
5630 * 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
5631 * 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
5632 *
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5633 * 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
5634 * or wipe_dummy_buffer() later!
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5635 *
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5636 * Returns NULL if it fails.
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5637 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5638 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5639 load_dummy_buffer(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5640 char_u *fname,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5641 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
5642 char_u *resulting_dir) // out: new directory
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5643 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5644 buf_T *newbuf;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5645 bufref_T newbufref;
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5646 bufref_T newbuf_to_wipe;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5647 int failed = TRUE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5648 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
5649 int readfile_result;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5650
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5651 // Allocate a buffer without putting it in the buffer list.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5652 newbuf = buflist_new(NULL, NULL, (linenr_T)1, BLN_DUMMY);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5653 if (newbuf == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5654 return NULL;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5655 set_bufref(&newbufref, newbuf);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5656
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5657 // Init the options.
177
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5658 buf_copy_options(newbuf, BCO_ENTER | BCO_NOHELP);
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5659
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5660 // 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
5661 if (ml_open(newbuf) == OK)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5662 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5663 // 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
5664 ++newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
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 // set curwin/curbuf to buf and save a few things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5667 aucmd_prepbuf(&aco, newbuf);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5668
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5669 // Need to set the filename for autocommands.
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5670 (void)setfname(curbuf, fname, NULL, FALSE);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5671
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5672 // Create swap file now to avoid the ATTENTION message.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5673 check_need_swap(TRUE);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
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 // 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
5676 // work.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5677 curbuf->b_flags &= ~BF_DUMMY;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5678
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5679 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
5680 readfile_result = readfile(fname, NULL,
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5681 (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
5682 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
5683 --newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5684 if (readfile_result == OK
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5685 && !got_int
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5686 && !(curbuf->b_flags & BF_NEW))
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5687 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5688 failed = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5689 if (curbuf != newbuf)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5690 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5691 // 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
5692 // 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
5693 // 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
5694 // window stuff.
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5695 set_bufref(&newbuf_to_wipe, newbuf);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5696 newbuf = curbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5697 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5698 }
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5699
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5700 // restore curwin/curbuf and a few other things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5701 aucmd_restbuf(&aco);
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5702 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
5703 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
5704
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5705 // 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
5706 // skip it.
9485
c16e207dc465 commit https://github.com/vim/vim/commit/ea3f2e7be447a8f0c4436869620f908de5e8ef1e
Christian Brabandt <cb@256bit.org>
parents: 9475
diff changeset
5707 newbuf->b_flags |= BF_DUMMY;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5708 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5709
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5710 // 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
5711 // 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
5712 // important.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5713 mch_dirname(resulting_dir, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5714 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5715
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5716 if (!bufref_valid(&newbufref))
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5717 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5718 if (failed)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5719 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5720 wipe_dummy_buffer(newbuf, dirname_start);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5721 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5722 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5723 return newbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5724 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5725
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5726 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5727 * 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
5728 * 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
5729 * 'autochdir' option have changed it.
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 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5732 wipe_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5733 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5734 if (curbuf != buf) // safety check
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5735 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5736 #if defined(FEAT_EVAL)
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5737 cleanup_T cs;
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5738
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5739 // 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
5740 // 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
5741 // work when got_int is set.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5742 enter_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5743 #endif
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5744
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5745 wipe_buffer(buf, FALSE);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5746
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5747 #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
5748 // 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
5749 // new aborting error, interrupt, or uncaught exception.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5750 leave_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5751 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5752 // 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
5753 restore_start_dir(dirname_start);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5754 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5755 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5756
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5757 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5758 * 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
5759 * 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
5760 * 'autochdir' option have changed it.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5761 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5762 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5763 unload_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5764 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5765 if (curbuf != buf) // safety check
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5766 {
3365
9ccdc4a69d8f updated for version 7.3.449
Bram Moolenaar <bram@vim.org>
parents: 3269
diff changeset
5767 close_buffer(NULL, buf, DOBUF_UNLOAD, FALSE);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5768
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5769 // 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
5770 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5771 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5772 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5773
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5774 #if defined(FEAT_EVAL) || defined(PROTO)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5775 /*
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5776 * 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
5777 * 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
5778 */
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5779 int
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5780 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
5781 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5782 qf_info_T *qi = qi_arg;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5783 dict_T *dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5784 char_u buf[2];
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5785 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5786 int i;
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5787 int bufnum;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5788
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5789 if (qi == NULL)
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5790 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5791 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
5792 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
5793 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5794 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
5795 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
5796 return FAIL;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5797 }
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5798 }
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5799
13800
e4dc4ede9ef8 patch 8.0.1772: quickfix: mixup of FALSE and FAIL, returning -1
Christian Brabandt <cb@256bit.org>
parents: 13764
diff changeset
5800 if (qf_idx == INVALID_QFIDX)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5801 qf_idx = qi->qf_curlist;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5802
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5803 if (qf_idx >= qi->qf_listcount || qf_list_empty(qi, qf_idx))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5804 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5805
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5806 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
5807 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
5808 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5809 // Handle entries with a non-existing buffer number.
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5810 bufnum = qfp->qf_fnum;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5811 if (bufnum != 0 && (buflist_findnr(bufnum) == NULL))
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5812 bufnum = 0;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5813
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5814 if ((dict = dict_alloc()) == NULL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5815 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5816 if (list_append_dict(list, dict) == FAIL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5817 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5818
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5819 buf[0] = qfp->qf_type;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5820 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
5821 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
5822 || 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
5823 || 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
5824 || 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
5825 || 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
5826 || 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
5827 || 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
5828 || 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
5829 || 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
5830 || dict_add_number(dict, "valid", (long)qfp->qf_valid) == FAIL)
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5831 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5832
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5833 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5834 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5835 break;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5836 }
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5837 return OK;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5838 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5839
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5840 // 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
5841 enum {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5842 QF_GETLIST_NONE = 0x0,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5843 QF_GETLIST_TITLE = 0x1,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5844 QF_GETLIST_ITEMS = 0x2,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5845 QF_GETLIST_NR = 0x4,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5846 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
5847 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
5848 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
5849 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
5850 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
5851 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
5852 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
5853 QF_GETLIST_ALL = 0x3FF,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5854 };
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5855
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5856 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5857 * 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
5858 * 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
5859 */
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5860 static int
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5861 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
5862 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5863 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
5864 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
5865 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
5866 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
5867 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
5868
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5869 // 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
5870 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
5871 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5872 // 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
5873 // option setting
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5874 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
5875 {
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5876 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
5877 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
5878 return FAIL;
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5879 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
5880 }
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5881
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5882 l = list_alloc();
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5883 if (l == NULL)
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5884 return FAIL;
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5885
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
5886 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
5887 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
5888 {
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5889 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
5890 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
5891 {
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5892 (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
5893 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
5894 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5895 free(qi);
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5896 }
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5897 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
5898 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
5899 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5900
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5901 return status;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5902 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5903
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5904 /*
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
5905 * 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
5906 */
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
5907 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
5908 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
5909 {
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
5910 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
5911
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5912 // 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
5913 // 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
5914 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
5915 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
5916 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
5917 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
5918 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
5919 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
5920 }
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
5921
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
5922 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5923 * Convert the keys in 'what' to quickfix list property flags.
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5924 */
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5925 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
5926 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
5927 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5928 int flags = QF_GETLIST_NONE;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5929
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5930 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
5931 {
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5932 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
5933 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
5934 // 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
5935 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
5936 }
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5937
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5938 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
5939 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
5940
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5941 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
5942 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
5943
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5944 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
5945 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
5946
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5947 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
5948 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
5949
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5950 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
5951 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
5952
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5953 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
5954 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
5955
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
5956 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
5957 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
5958
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5959 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
5960 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
5961
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5962 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
5963 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
5964
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
5965 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
5966 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
5967
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5968 return flags;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5969 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5970
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5971 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5972 * 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
5973 * 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
5974 * quickfix list index.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5975 * 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
5976 * 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
5977 * 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
5978 * 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
5979 * 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
5980 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5981 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5982 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
5983 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5984 int qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5985 dictitem_T *di;
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 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
5988 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
5989 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5990 // 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
5991 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
5992 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5993 // 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
5994 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
5995 {
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5996 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
5997 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
5998 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
5999 }
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
6000 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6001 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
6002 && 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
6003 && 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
6004 // 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
6005 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
6006 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6007 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
6008 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6009
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6010 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
6011 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6012 // 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
6013 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
6014 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6015 // 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
6016 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
6017 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
6018 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6019 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6020 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
6021 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6022
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6023 return qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6024 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6025
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6026 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6027 * 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
6028 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6029 static int
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6030 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
6031 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6032 int status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6033
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6034 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
6035 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
6036 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
6037 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6038 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
6039 if (l != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6040 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
6041 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6042 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6043 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6044 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
6045 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
6046 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
6047 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
6048 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
6049 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
6050 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
6051 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
6052 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
6053 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
6054 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
6055 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
6056 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
6057 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
6058 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
6059 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
6060
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6061 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6062 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6063
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6064 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6065 * 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
6066 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6067 static int
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6068 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
6069 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6070 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
6071 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6072
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6073 /*
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
6074 * 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
6075 * 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
6076 * 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
6077 */
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6078 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
6079 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
6080 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6081 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
6082
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6083 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
6084 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6085 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
6086 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
6087 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
6088 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6089
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6090 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
6091 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6092
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6093 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6094 * 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
6095 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6096 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6097 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
6098 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6099 int status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6100 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
6101 if (l != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6102 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6103 (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
6104 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
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 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6110 }
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 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6113 * 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
6114 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6115 static int
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6116 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
6117 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6118 int status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6119 dictitem_T *di;
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 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
6122 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6123 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
6124 if (di != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6125 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6126 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
6127 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
6128 if (status == FAIL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6129 dictitem_free(di);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6130 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6131 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6132 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6133 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6134 else
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6135 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
6136
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6137 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6138 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6139
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6140 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6141 * 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
6142 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6143 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6144 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
6145 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6146 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
6147 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
6148 // 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
6149 curidx = 0;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6150 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
6151 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6152
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6153 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6154 * 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
6155 * 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
6156 * 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
6157 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6158 int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6159 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
6160 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6161 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
6162 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
6163 int status = OK;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6164 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
6165 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6166 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
6167
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6168 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
6169 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
6170
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6171 if (wp != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6172 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
6173
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
6174 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
6175
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6176 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
6177 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
6178
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6179 // 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
6180 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
6181 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
6182
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
6183 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
6184
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6185 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
6186 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
6187 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
6188 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
6189 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
6190 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
6191 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
6192 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
6193 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
6194 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
6195 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
6196 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
6197 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
6198 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
6199 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
6200 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
6201 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
6202 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
6203 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
6204 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
6205
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6206 return status;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6207 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6208
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6209 /*
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6210 * 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
6211 * 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
6212 * 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
6213 */
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6214 static int
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6215 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
6216 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
6217 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
6218 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
6219 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
6220 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
6221 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6222 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
6223 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
6224 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
6225 long lnum;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6226
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6227 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
6228 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
6229
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
6230 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
6231 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
6232 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
6233 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
6234 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
6235 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
6236 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
6237 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
6238 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
6239 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
6240 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
6241 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
6242
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6243 valid = TRUE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6244 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
6245 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6246
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6247 // 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
6248 // 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
6249 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
6250 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6251 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
6252 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6253 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
6254 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
6255 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6256 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6257 bufnum = 0;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6258 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6259
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6260 // 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
6261 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
6262 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
6263
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6264 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
6265 qf_idx,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6266 NULL, // dir
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6267 filename,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6268 module,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6269 bufnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6270 text,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6271 lnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6272 col,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6273 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
6274 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
6275 nr,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6276 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
6277 valid);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6278
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6279 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
6280 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
6281 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
6282 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
6283 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
6284
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6285 if (valid)
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6286 *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
6287
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6288 return status;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6289 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6290
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6291 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6292 * 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
6293 * a dictionary with item information.
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6294 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6295 static int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6296 qf_add_entries(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6297 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
6298 int qf_idx,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6299 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6300 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6301 int action)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6302 {
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
6303 qf_list_T *qfl = &qi->qf_lists[qf_idx];
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6304 listitem_T *li;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6305 dict_T *d;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
6306 qfline_T *old_last = NULL;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6307 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
6308 int valid_entry = FALSE;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6309
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6310 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
6311 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6312 // make place for a new list
3965
eccae034465b updated for version 7.3.738
Bram Moolenaar <bram@vim.org>
parents: 3949
diff changeset
6313 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
6314 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
6315 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
6316 }
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
6317 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
6318 // 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
6319 old_last = qfl->qf_last;
277
fe16c18c24a7 updated for version 7.0074
vimboss
parents: 273
diff changeset
6320 else if (action == 'r')
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6321 {
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
6322 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
6323 qf_store_title(qfl, title);
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6324 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6325
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6326 for (li = list->lv_first; li != NULL; li = li->li_next)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6327 {
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6328 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
6329 continue; // Skip non-dict items
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6330
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6331 d = li->li_tv.vval.v_dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6332 if (d == NULL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6333 continue;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6334
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6335 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
6336 &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
6337 if (retval == FAIL)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6338 break;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6339 }
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6340
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6341 // 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
6342 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
6343 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
6344 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
6345 // 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
6346 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
6347
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6348 // 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
6349 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
6350 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
6351
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6352 // 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
6353 // 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
6354 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
6355 qfl->qf_index = 1;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6356
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6357 // 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
6358 qf_update_buffer(qi, old_last);
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6359
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6360 return retval;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6361 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6362
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6363 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6364 * 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
6365 */
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6366 static int
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6367 qf_setprop_get_qfidx(
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6368 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6369 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6370 int action,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6371 int *newlist)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6372 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6373 dictitem_T *di;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6374 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
6375
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6376 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
6377 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6378 // 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
6379 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
6380 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6381 // 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
6382 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
6383 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
6384
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6385 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
6386 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6387 // 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
6388 // 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
6389 // stack.
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6390 *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
6391 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
6392 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6393 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
6394 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
6395 else if (action != ' ')
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6396 *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
6397 }
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6398 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
6399 && 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
6400 && 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
6401 {
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6402 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
6403 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
6404 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
6405 qf_idx = 0;
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6406 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6407 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
6408 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6409 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6410 return INVALID_QFIDX;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6411 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6412
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6413 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
6414 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6415 // 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
6416 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
6417 return INVALID_QFIDX;
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 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
6420 }
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 return qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6423 }
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 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6426 * 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
6427 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6428 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6429 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
6430 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6431 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
6432
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6433 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
6434 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6435
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6436 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
6437 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
6438 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
6439 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
6440
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6441 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6442 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6443
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6444 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6445 * 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
6446 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6447 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6448 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
6449 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6450 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6451 char_u *title_save;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6452
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6453 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
6454 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6455
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6456 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
6457 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
6458 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
6459 vim_free(title_save);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6460
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6461 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6462 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6463
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6464 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6465 * 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
6466 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6467 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6468 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
6469 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6470 int qf_idx,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6471 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6472 dictitem_T *di,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6473 int action)
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 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
6476 dictitem_T *efm_di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6477 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6478
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6479 // 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
6480 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
6481 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6482 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
6483 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
6484 return FAIL;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6485 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
6486 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6487
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6488 // 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
6489 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
6490 return FAIL;
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 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
6493 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
6494 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
6495 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
6496 retval = OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6497
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6498 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6499 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6500
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6501 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6502 * Set quickfix list context.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6503 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6504 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
6505 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
6506 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6507 typval_T *ctx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6508
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
6509 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
6510 ctx = alloc_tv();
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6511 if (ctx != NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6512 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
6513 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
6514
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6515 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6516 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6517
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6518 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6519 * 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
6520 */
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6521 static int
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6522 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
6523 {
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6524 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
6525 int newidx;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6526 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
6527 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
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 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
6530 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
6531 && 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
6532 && 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
6533 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
6534 else
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 // 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
6537 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
6538 if (denote)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6539 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6540 }
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6541
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6542 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
6543 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6544 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
6545 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
6546
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6547 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
6548 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
6549 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
6550 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6551 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
6552 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
6553
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6554 // 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
6555 // 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
6556 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
6557 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
6558
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6559 return OK;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6560 }
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6561
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6562 /*
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6563 * 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
6564 * 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
6565 * 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
6566 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6567 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6568 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
6569 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6570 dictitem_T *di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6571 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6572 int qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6573 int newlist = FALSE;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6574 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
6575
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6576 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
6577 newlist = TRUE;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6578
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6579 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
6580 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
6581 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
6582
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6583 if (newlist)
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6584 {
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6585 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
6586 qf_new_list(qi, title);
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6587 qf_idx = qi->qf_curlist;
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6588 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6589
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6590 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
6591 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
6592 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
6593 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
6594 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
6595 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
6596 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
6597 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
6598 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
6599 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
6600 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
6601
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6602 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6603 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
6604
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6605 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6606 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6607
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6608 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6609 * 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
6610 * 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
6611 */
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6612 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
6613 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
6614 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6615 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
6616
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6617 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
6618 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
6619 return wp;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6620
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6621 return NULL;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6622 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6623
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6624 /*
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6625 * 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
6626 * 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
6627 */
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6628 static void
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6629 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
6630 {
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6631 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
6632 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
6633 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
6634
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6635 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
6636 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6637 // 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
6638 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
6639 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
6640 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
6641 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6642
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6643 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
6644 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6645 // 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
6646 // 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
6647 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
6648 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
6649 wp = llwin;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6650 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6651
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6652 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
6653 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
6654 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6655 // 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
6656 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
6657 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
6658 }
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6659 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
6660 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6661 // 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
6662 // location list
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6663 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
6664
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6665 // 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
6666 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
6667
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6668 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
6669 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
6670 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6671 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
6672 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
6673 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
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 }
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6676
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6677 /*
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6678 * 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
6679 * 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
6680 * "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
6681 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6682 int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6683 set_errorlist(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6684 win_T *wp,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6685 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6686 int action,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6687 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6688 dict_T *what)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6689 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6690 qf_info_T *qi = &ql_info;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6691 int retval = OK;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6692
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6693 if (wp != NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6694 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6695 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
6696 if (qi == NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6697 return FAIL;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6698 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6699
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6700 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
6701 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6702 // 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
6703 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
6704 return OK;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6705 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6706
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6707 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6708
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6709 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
6710 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
6711 else
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6712 {
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6713 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
6714 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6715 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
6716 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6717
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6718 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6719
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6720 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6721 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6722
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6723 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6724 * 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
6725 */
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6726 static int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6727 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
6728 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6729 int i;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6730 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6731 typval_T *ctx;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6732
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6733 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
6734 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6735 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
6736 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
6737 && 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
6738 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
6739 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6740
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6741 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6742 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6743
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6744 /*
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6745 * 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
6746 * "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
6747 */
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6748 int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6749 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
6750 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6751 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6752 tabpage_T *tp;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6753 win_T *win;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6754
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6755 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
6756 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6757 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6758
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6759 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
6760 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6761 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
6762 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6763 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
6764 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6765 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6766 }
13074
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6767 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
6768 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6769 // 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
6770 // 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
6771 // 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
6772 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
6773 if (abort)
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6774 return abort;
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6775 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6776 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6777
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6778 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6779 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6780 #endif
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6781
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
6782 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6783 * ":[range]cbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6784 * ":[range]caddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6785 * ":[range]cgetbuffer [bufnr]" command.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6786 * ":[range]lbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6787 * ":[range]laddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6788 * ":[range]lgetbuffer [bufnr]" command.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6789 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6790 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6791 ex_cbuffer(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6792 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6793 buf_T *buf = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6794 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
6795 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
6796 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
6797 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
6798 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6799
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6800 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6801 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6802 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
6803 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
6804 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
6805 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
6806 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
6807 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
6808 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6809 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6810 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
6811 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6812 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6813 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6814 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6815 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6816 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6817 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6818
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6819 // 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
6820 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
6821 {
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6822 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
6823 if (qi == NULL)
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6824 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6825 wp = curwin;
13076
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6826 }
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6827
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6828 if (*eap->arg == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6829 buf = curbuf;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6830 else if (*skipwhite(skipdigits(eap->arg)) == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6831 buf = buflist_findnr(atoi((char *)eap->arg));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6832 if (buf == NULL)
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
6833 emsg(_(e_invarg));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6834 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
6835 emsg(_("E681: Buffer is not loaded"));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6836 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6837 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6838 if (eap->addr_count == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6839 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6840 eap->line1 = 1;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6841 eap->line2 = buf->b_ml.ml_line_count;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6842 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6843 if (eap->line1 < 1 || eap->line1 > buf->b_ml.ml_line_count
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6844 || 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
6845 emsg(_(e_invrange));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6846 else
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6847 {
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
6848 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
6849
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6850 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
6851 {
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6852 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
6853 (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
6854 qf_title = IObuff;
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6855 }
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6856
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6857 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6858
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6859 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
6860 (eap->cmdidx != CMD_caddbuffer
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6861 && 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
6862 eap->line1, eap->line2,
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6863 qf_title, NULL);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6864 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
6865 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6866 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6867 return;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6868 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6869 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6870 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
6871
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6872 // 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
6873 // 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
6874 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
6875 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
6876 {
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6877 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
6878
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6879 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
6880 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
6881 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
6882 // 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
6883 // be invalid.
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6884 res = 0;
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6885 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6886 // 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
6887 // free the list.
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6888 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
6889 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
6890 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6891 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6892 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
6893
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6894 decr_quickfix_busy();
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6895 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6896 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6897 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6898
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
6899 #if defined(FEAT_EVAL) || defined(PROTO)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6900 /*
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6901 * ":cexpr {expr}", ":cgetexpr {expr}", ":caddexpr {expr}" command.
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6902 * ":lexpr {expr}", ":lgetexpr {expr}", ":laddexpr {expr}" command.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6903 */
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6904 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6905 ex_cexpr(exarg_T *eap)
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6906 {
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6907 typval_T *tv;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6908 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
6909 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
6910 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
6911 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
6912 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6913
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6914 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6915 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6916 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
6917 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
6918 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
6919 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
6920 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
6921 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
6922 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6923 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6924 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
6925 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6926 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6927 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6928 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6929 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6930 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6931 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6932
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
6933 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
6934 {
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6935 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
6936 if (qi == NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6937 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6938 wp = curwin;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6939 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6940
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6941 // 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
6942 // use it to fill the errorlist.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6943 tv = eval_expr(eap->arg, NULL);
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6944 if (tv != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6945 {
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6946 if ((tv->v_type == VAR_STRING && tv->vval.v_string != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6947 || (tv->v_type == VAR_LIST && tv->vval.v_list != NULL))
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6948 {
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6949 incr_quickfix_busy();
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6950 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
6951 (eap->cmdidx != CMD_caddexpr
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6952 && 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
6953 (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
6954 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
6955 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
6956 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6957 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6958 goto cleanup;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6959 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6960 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6961 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
6962
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6963 // 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
6964 // 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
6965 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
6966 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6967 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
6968 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
6969
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6970 // 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
6971 // free the list.
14111
678e326bf7eb patch 8.1.0073: crash when autocommands call setloclist()
Christian Brabandt <cb@256bit.org>
parents: 14085
diff changeset
6972 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
6973 || 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
6974 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6975 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6976 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
6977 decr_quickfix_busy();
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6978 }
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6979 else
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
6980 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
6981 cleanup:
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6982 free_tv(tv);
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6983 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6984 }
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
6985 #endif
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6986
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6987 /*
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6988 * 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
6989 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6990 static qf_info_T *
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6991 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
6992 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6993 win_T *wp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6994 qf_info_T *qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6995
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6996 // 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
6997 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
6998 wp = curwin;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6999 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7000 // 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
7001 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
7002
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7003 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
7004 qi = NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7005 else
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7006 qi = wp->w_llist;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7007
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7008 if (qi == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7009 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7010 // 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
7011 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
7012 return NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7013 *new_ll = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7014 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7015
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7016 return qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7017 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7018
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7019 /*
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7020 * 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
7021 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7022 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7023 hgr_search_file(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7024 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7025 char_u *fname,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7026 vimconv_T *p_vc,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7027 regmatch_T *p_regmatch)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7028 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7029 FILE *fd;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7030 long lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7031
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7032 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
7033 if (fd == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7034 return;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7035
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7036 lnum = 1;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7037 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
7038 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7039 char_u *line = IObuff;
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7040
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7041 // 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
7042 // 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
7043 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
7044 && has_non_ascii(IObuff))
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7045 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7046 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
7047 if (line == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7048 line = IObuff;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7049 }
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 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
7052 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7053 int l = (int)STRLEN(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7054
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7055 // 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
7056 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
7057 line[--l] = NUL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7058
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7059 if (qf_add_entry(qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7060 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7061 NULL, // dir
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7062 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
7063 NULL,
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7064 0,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7065 line,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7066 lnum,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7067 (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
7068 + 1, // col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7069 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7070 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7071 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7072 1, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7073 TRUE // valid
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7074 ) == FAIL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7075 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7076 got_int = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7077 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7078 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7079 break;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7080 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7081 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7082 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7083 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7084 ++lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7085 line_breakcheck();
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7086 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7087 fclose(fd);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7088 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7089
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 * 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
7092 * the given directory.
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7093 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7094 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7095 hgr_search_files_in_dir(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7096 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7097 char_u *dirname,
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7098 regmatch_T *p_regmatch,
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7099 vimconv_T *p_vc
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7100 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7101 , char_u *lang
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 )
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7104 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7105 int fcount;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7106 char_u **fnames;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7107 int fi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7108
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7109 // 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
7110 add_pathsep(dirname);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7111 STRCAT(dirname, "doc/*.\\(txt\\|??x\\)");
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7112 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
7113 &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
7114 && fcount > 0)
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 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
7117 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7118 #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
7119 // 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
7120 if (lang != NULL
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7121 && 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
7122 + 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
7123 && !(STRNICMP(lang, "en", 2) == 0
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7124 && STRNICMP("txt", fnames[fi]
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7125 + 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
7126 continue;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7127 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7128
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7129 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
7130 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7131 FreeWild(fcount, fnames);
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 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7134
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7135 /*
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
7136 * 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
7137 * 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
7138 * '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
7139 * specified language are found.
13764
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 static void
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7142 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
7143 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7144 char_u *p;
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 vimconv_T vc;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7147
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7148 // 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
7149 // differs.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7150 vc.vc_type = CONV_NONE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7151 if (!enc_utf8)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7152 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
7153
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7154 // 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
7155 p = p_rtp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7156 while (*p != NUL && !got_int)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7157 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7158 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
7159
15603
639b8318472c patch 8.1.0809: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents: 15543
diff changeset
7160 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
7161 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7162 , lang
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7163 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7164 );
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7165 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7166
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7167 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
7168 convert_setup(&vc, NULL, NULL);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7169 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7170
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7171 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7172 * ":helpgrep {pattern}"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7173 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7174 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
7175 ex_helpgrep(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7176 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7177 regmatch_T regmatch;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7178 char_u *save_cpo;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
7179 qf_info_T *qi = &ql_info;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7180 int new_qi = FALSE;
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7181 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
7182 char_u *lang = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7183
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7184 switch (eap->cmdidx)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7185 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7186 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
7187 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
7188 default: break;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7189 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7190 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
7191 curbuf->b_fname, TRUE, curbuf))
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7192 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7193 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7194 if (aborting())
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7195 return;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7196 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7197 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7198
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7199 // 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
7200 save_cpo = p_cpo;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7201 p_cpo = empty_option;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7202
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
7203 if (is_loclist_cmd(eap->cmdidx))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7204 {
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7205 qi = hgr_get_ll(&new_qi);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7206 if (qi == NULL)
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7207 return;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7208 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7209
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7210 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7211
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7212 #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
7213 // 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
7214 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
7215 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7216 regmatch.regprog = vim_regcomp(eap->arg, RE_MAGIC + RE_STRING);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7217 regmatch.rm_ic = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7218 if (regmatch.regprog != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7219 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7220 qf_list_T *qfl;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7221
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7222 // 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
7223 qf_new_list(qi, qf_cmdtitle(*eap->cmdlinep));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7224
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7225 hgr_search_in_rtp(qi, &regmatch, lang);
3257
75217982ea46 updated for version 7.3.397
Bram Moolenaar <bram@vim.org>
parents: 3242
diff changeset
7226
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
7227 vim_regfree(regmatch.regprog);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7228
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7229 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
7230 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7231 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
7232 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7233 qf_list_changed(qfl);
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7234 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7235 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7236
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7237 if (p_cpo == empty_option)
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7238 p_cpo = save_cpo;
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7239 else
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7240 // Darn, some plugin changed the value.
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7241 free_string_option(save_cpo);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7242
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7243 if (au_name != NULL)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7244 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7245 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7246 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
7247 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
7248 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7249 // 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
7250 decr_quickfix_busy();
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7251 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7252 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7253 }
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7254
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7255 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
7256 if (!qf_list_empty(qi, qi->qf_curlist))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7257 qf_jump(qi, 0, 0, FALSE);
9
4102fb4ea781 updated for version 7.0002
vimboss
parents: 7
diff changeset
7258 else
15470
55ccc2d353bd patch 8.1.0743: giving error messages is not flexible
Bram Moolenaar <Bram@vim.org>
parents: 15424
diff changeset
7259 semsg(_(e_nomatch2), eap->arg);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7260
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7261 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7262
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7263 if (eap->cmdidx == CMD_lhelpgrep)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7264 {
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7265 // 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
7266 // 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
7267 if (!bt_help(curwin->w_buffer) || curwin->w_llist == qi)
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7268 {
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7269 if (new_qi)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7270 ll_free_all(&qi);
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7271 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7272 else if (curwin->w_llist == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7273 curwin->w_llist = qi;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7274 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7275 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7276
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7277 #endif /* FEAT_QUICKFIX */