annotate src/quickfix.c @ 15424:90c8ff9c19ee v8.1.0720

patch 8.1.0720: cannot easily change the current quickfx list index commit https://github.com/vim/vim/commit/5b69c22fd2bf0c0d32aab90ee4c7ef74259d2c4c Author: Bram Moolenaar <Bram@vim.org> Date: Fri Jan 11 14:50:06 2019 +0100 patch 8.1.0720: cannot easily change the current quickfx list index Problem: Cannot easily change the current quickfx list index. Solution: Add the "idx" argument to setqflist(). (Yegappan Lakshmanan, closes #3701)
author Bram Moolenaar <Bram@vim.org>
date Fri, 11 Jan 2019 15:00:08 +0100
parents a413374825dd
children 55ccc2d353bd
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,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
242 int round,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
243 char_u *errmsg)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
244 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
245 char_u *srcptr;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
246
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
247 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
248 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
249 // Each errorformat pattern can occur only once
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
250 sprintf((char *)errmsg,
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
251 _("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
252 EMSG(errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
253 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
254 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
255 if ((idx && idx < 6
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
256 && 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
257 || (idx == 6
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
258 && 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
259 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
260 sprintf((char *)errmsg,
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
261 _("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
262 EMSG(errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
263 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
264 }
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
265 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
266 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
267 *regpat++ = '(';
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
268 #ifdef BACKSLASH_IN_FILENAME
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
269 if (*efmpat == 'f')
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
270 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
271 // 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
272 // 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
273 // "\%(\a:\)\="
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
274 STRCPY(regpat, "\\%(\\a:\\)\\=");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
275 regpat += 10;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
276 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
277 #endif
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
278 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
279 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
280 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
281 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
282 // 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
283 // 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
284 // 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
285 // 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
286 // follows should work.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
287 STRCPY(regpat, ".\\{-1,}");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
288 regpat += 7;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
289 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
290 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
291 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
292 // 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
293 // 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
294 STRCPY(regpat, "\\f\\+");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
295 regpat += 4;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
296 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
297 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
298 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
299 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
300 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
301 while ((*regpat = *srcptr++) != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
302 ++regpat;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
303 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
304 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
305 *regpat++ = ')';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
306
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
307 return regpat;
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
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
310 /*
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
311 * 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
312 * 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
313 */
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
314 static char_u *
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
315 scanf_fmt_to_regpat(
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
316 char_u **pefmp,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
317 char_u *efm,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
318 int len,
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
319 char_u *regpat,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
320 char_u *errmsg)
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 char_u *efmp = *pefmp;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
323
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
324 if (*efmp == '[' || *efmp == '\\')
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
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 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
327 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
328 if (efmp[1] == '^')
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
329 *regpat++ = *++efmp;
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 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
332 *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
333 while (efmp < efm + len
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
334 && (*regpat++ = *++efmp) != ']')
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
335 // skip ;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
336 if (efmp == efm + len)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
337 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
338 EMSG(_("E374: Missing ] in format string"));
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
339 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
340 }
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 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
343 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
344 *regpat++ = *++efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
345 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
346 *regpat++ = '+';
13984
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 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
349 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
350 // TODO: scanf()-like: %*ud, %*3c, %*f, ... ?
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
351 sprintf((char *)errmsg,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
352 _("E375: Unsupported %%%c in format string"), *efmp);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
353 EMSG(errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
354 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
355 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
356
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
357 *pefmp = efmp;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
358
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
359 return regpat;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
360 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
361
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
362 /*
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
363 * 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
364 */
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
365 static char_u *
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
366 efm_analyze_prefix(char_u *efmp, efm_T *efminfo, char_u *errmsg)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
367 {
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
368 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
369 efminfo->flags = *efmp++;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
370 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
371 efminfo->prefix = *efmp;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
372 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
373 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
374 sprintf((char *)errmsg,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
375 _("E376: Invalid %%%c in format string prefix"), *efmp);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
376 EMSG(errmsg);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
377 return NULL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
378 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
379
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
380 return efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
381 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
382
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
383 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
384 * 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
385 * 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
386 * 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
387 * Returns OK or FAIL.
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
388 */
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
389 static int
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
390 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
391 char_u *efm,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
392 int len,
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
393 efm_T *fmt_ptr,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
394 char_u *regpat,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
395 char_u *errmsg)
9365
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 char_u *ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
398 char_u *efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
399 int round;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
400 int idx = 0;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
401
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
402 // 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
403 ptr = regpat;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
404 *ptr++ = '^';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
405 round = 0;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
406 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
407 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
408 if (*efmp == '%')
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 ++efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
411 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
412 if (fmt_pat[idx].convchar == *efmp)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
413 break;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
414 if (idx < FMT_PATTERNS)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
415 {
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
416 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
417 errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
418 if (ptr == NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
419 return FAIL;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
420 round++;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
421 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
422 else if (*efmp == '*')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
423 {
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
424 ++efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
425 ptr = scanf_fmt_to_regpat(&efmp, efm, len, ptr, errmsg);
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
426 if (ptr == NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
427 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
428 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
429 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
430 *ptr++ = *efmp; // regexp magic characters
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
431 else if (*efmp == '#')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
432 *ptr++ = '*';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
433 else if (*efmp == '>')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
434 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
435 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
436 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
437 // 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
438 // option part
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
439 efmp = efm_analyze_prefix(efmp, fmt_ptr, errmsg);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
440 if (efmp == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
441 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
442 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
443 else
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
444 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
445 sprintf((char *)errmsg,
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
446 _("E377: Invalid %%%c in format string"), *efmp);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
447 EMSG(errmsg);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
448 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
449 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
450 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
451 else // copy normal character
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
452 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
453 if (*efmp == '\\' && efmp + 1 < efm + len)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
454 ++efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
455 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
456 *ptr++ = '\\'; // escape regexp atoms
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
457 if (*efmp)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
458 *ptr++ = *efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
459 }
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 *ptr++ = '$';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
462 *ptr = NUL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
463
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
464 return OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
465 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
466
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
467 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
468 * Free the 'errorformat' information list
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
469 */
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
470 static void
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
471 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
472 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
473 efm_T *efm_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
474
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
475 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
476 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
477 *efm_first = efm_ptr->next;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
478 vim_regfree(efm_ptr->prog);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
479 vim_free(efm_ptr);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
480 }
10367
4e4e116e3689 commit https://github.com/vim/vim/commit/63bed3d319b5d90765dbdae93a3579b6322d79fb
Christian Brabandt <cb@256bit.org>
parents: 10359
diff changeset
481 fmt_start = NULL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
482 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
483
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
484 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
485 * 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
486 * a regular expression pattern.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
487 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
488 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
489 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
490 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
491 int sz;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
492 int i;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
493
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
494 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
495 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
496 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
497 #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
498 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
499 #else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
500 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
501 #endif
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
502
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
503 return sz;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
504 }
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 * 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
508 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
509 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
510 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
511 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
512 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
513
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
514 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
515 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
516 ++len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
517
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
518 return len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
519 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
520
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
521 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
522 * 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
523 * 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
524 * the parsed 'errorformat' option.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
525 */
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
526 static efm_T *
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
527 parse_efm_option(char_u *efm)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
528 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
529 char_u *errmsg = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
530 int errmsglen;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
531 efm_T *fmt_ptr = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
532 efm_T *fmt_first = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
533 efm_T *fmt_last = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
534 char_u *fmtstr = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
535 int len;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
536 int sz;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
537
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
538 errmsglen = CMDBUFFSIZE + 1;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
539 errmsg = alloc_id(errmsglen, aid_qf_errmsg);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
540 if (errmsg == NULL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
541 goto parse_efm_end;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
542
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
543 // 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
544 // 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
545
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
546 // 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
547 sz = efm_regpat_bufsz(efm);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
548 if ((fmtstr = alloc(sz)) == NULL)
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
549 goto parse_efm_error;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
550
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
551 while (efm[0] != NUL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
552 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
553 // 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
554 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
555 if (fmt_ptr == NULL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
556 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
557 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
558 fmt_first = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
559 else
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
560 fmt_last->next = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
561 fmt_last = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
562
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
563 // 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
564 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
565
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
566 if (efm_to_regpat(efm, len, fmt_ptr, fmtstr, errmsg) == FAIL)
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
567 goto parse_efm_error;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
568 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
569 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
570 // Advance to next part
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
571 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
572 }
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
573
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
574 if (fmt_first == NULL) // nothing found
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
575 EMSG(_("E378: 'errorformat' contains no pattern"));
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
576
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
577 goto parse_efm_end;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
578
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
579 parse_efm_error:
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
580 free_efm_list(&fmt_first);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
581
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
582 parse_efm_end:
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
583 vim_free(fmtstr);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
584 vim_free(errmsg);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
585
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
586 return fmt_first;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
587 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
588
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
589 enum {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
590 QF_FAIL = 0,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
591 QF_OK = 1,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
592 QF_END_OF_INPUT = 2,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
593 QF_NOMEM = 3,
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
594 QF_IGNORE_LINE = 4,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
595 QF_MULTISCAN = 5,
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
596 };
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
597
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
598 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
599 * 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
600 * list.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
601 */
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
602 typedef struct {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
603 char_u *linebuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
604 int linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
605 char_u *growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
606 int growbufsiz;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
607 FILE *fd;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
608 typval_T *tv;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
609 char_u *p_str;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
610 listitem_T *p_li;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
611 buf_T *buf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
612 linenr_T buflnum;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
613 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
614 vimconv_T vc;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
615 } qfstate_T;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
616
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
617 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
618 * 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
619 */
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
620 static char_u *
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
621 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
622 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
623 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
624
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
625 // 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
626 // 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
627 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
628 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
629 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
630 state->growbuf = alloc(state->linelen + 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
631 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
632 return NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
633 state->growbufsiz = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
634 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
635 else if (state->linelen > state->growbufsiz)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
636 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
637 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
638 return NULL;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
639 state->growbuf = p;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
640 state->growbufsiz = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
641 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
642 return state->growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
643 }
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 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
646 * 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
647 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
648 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
649 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
650 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
651 // 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
652 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
653 char_u *p;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
654 int len;
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 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
657 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
658
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
659 p = vim_strchr(p_str, '\n');
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
660 if (p != NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
661 len = (int)(p - p_str) + 1;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
662 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
663 len = (int)STRLEN(p_str);
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 if (len > IOSIZE - 2)
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 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
668 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
669 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
670 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
671 else
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 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
674 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
675 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
676 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
677
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
678 // 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
679 // 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
680 p_str += len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
681 state->p_str = p_str;
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 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
684 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
685
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 * 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
688 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
689 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
690 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
691 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
692 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
693 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
694
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
695 while (p_li != NULL
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
696 && (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
697 || 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
698 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
699
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
700 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
701 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
702 state->p_li = NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
703 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
704 }
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 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
707 if (len > IOSIZE - 2)
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 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
710 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
711 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
712 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
713 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
714 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
715 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
716 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
717 }
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 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
720
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
721 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
722 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
723 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
724
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 * 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
727 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
728 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
729 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
730 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
731 char_u *p_buf = NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
732 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
733
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
734 // 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
735 if (state->buflnum > state->lnumlast)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
736 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
737
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
738 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
739 state->buflnum += 1;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
740
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
741 len = (int)STRLEN(p_buf);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
742 if (len > IOSIZE - 2)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
743 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
744 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
745 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
746 return QF_NOMEM;
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 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
749 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
750 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
751 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
752 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
753 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
754
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
755 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
756 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
757
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
758 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
759 * 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
760 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
761 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
762 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
763 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
764 int discard;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
765 int growbuflen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
766
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
767 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
768 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
769
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
770 discard = FALSE;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
771 state->linelen = (int)STRLEN(IObuff);
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
772 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
773 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
774 // 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
775 // 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
776 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
777 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
778 state->growbufsiz = 2 * (IOSIZE - 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
779 state->growbuf = alloc(state->growbufsiz);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
780 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
781 return QF_NOMEM;
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
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
784 // 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
785 memcpy(state->growbuf, IObuff, IOSIZE - 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
786 growbuflen = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
787
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
788 for (;;)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
789 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
790 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
791
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
792 if (fgets((char *)state->growbuf + growbuflen,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
793 state->growbufsiz - growbuflen, state->fd) == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
794 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
795 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
796 growbuflen += state->linelen;
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
797 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
798 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
799 if (state->growbufsiz == LINE_MAXLEN)
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 discard = TRUE;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
802 break;
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
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
805 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
806 ? 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
807 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
808 return QF_NOMEM;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
809 state->growbuf = p;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
810 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
811
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
812 while (discard)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
813 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
814 // 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
815 // 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
816 // reached.
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
817 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
818 || (int)STRLEN(IObuff) < IOSIZE - 1
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
819 || IObuff[IOSIZE - 1] == '\n')
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
820 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
821 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
822
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
823 state->linebuf = state->growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
824 state->linelen = growbuflen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
825 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
826 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
827 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
828
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
829 #ifdef FEAT_MBYTE
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
830 // 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
831 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
832 {
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
833 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
834
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
835 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
836 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
837 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
838 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
839 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
840 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
841 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
842 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
843 else
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
844 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
845 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
846 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
847 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
848 ? 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
849 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
850 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
851 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
852 #endif
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
853
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
854 return QF_OK;
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
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
857 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
858 * 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
859 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
860 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
861 qf_get_nextline(qfstate_T *state)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
862 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
863 int status = QF_FAIL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
864
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
865 if (state->fd == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
866 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
867 if (state->tv != NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
868 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
869 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
870 // 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
871 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
872 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
873 // 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
874 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
875 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
876 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
877 // 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
878 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
879 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
880 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
881 // 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
882 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
883
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
884 if (status != QF_OK)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
885 return status;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
886
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
887 // 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
888 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
889 {
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
890 state->linebuf[state->linelen - 1] = NUL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
891 #ifdef USE_CRNL
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
892 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
893 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
894 #endif
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
895 }
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
896
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
897 #ifdef FEAT_MBYTE
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
898 remove_bom(state->linebuf);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
899 #endif
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
900
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
901 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
902 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
903
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
904 typedef struct {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
905 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
906 char_u *module;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
907 char_u *errmsg;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
908 int errmsglen;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
909 long lnum;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
910 int col;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
911 char_u use_viscol;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
912 char_u *pattern;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
913 int enr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
914 int type;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
915 int valid;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
916 } qffields_T;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
917
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
918 /*
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
919 * 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
920 * 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
921 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
922 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
923 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
924 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
925 int c;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
926
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
927 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
928 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
929
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
930 // 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
931 c = *rmp->endp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
932 *rmp->endp[midx] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
933 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
934 *rmp->endp[midx] = c;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
935
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
936 // 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
937 // should exist.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
938 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
939 && mch_getperm(fields->namebuf) == -1)
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
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 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
947 * 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
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_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
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->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
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 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
960 * 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
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_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
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->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
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 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
973 * 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
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_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
977 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
978 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
979 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
980 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
981 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
982 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
983
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
984 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
985 * 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
986 * 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
987 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
988 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
989 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
990 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
991 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
992 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
993 fields->type = *rmp->startp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
994 return QF_OK;
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
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
997 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
998 * 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
999 * 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
1000 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1001 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1002 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
1003 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1004 char_u *p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1005
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1006 if (linelen >= fields->errmsglen)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1007 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1008 // linelen + null terminator
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1009 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
1010 return QF_NOMEM;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1011 fields->errmsg = p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1012 fields->errmsglen = linelen + 1;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1013 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1014 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
1015 return QF_OK;
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 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1019 * 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
1020 * 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
1021 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1022 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1023 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
1024 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1025 char_u *p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1026 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1027
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1028 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
1029 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1030 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
1031 if (len >= fields->errmsglen)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1032 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1033 // len + null terminator
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1034 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
1035 return QF_NOMEM;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1036 fields->errmsg = p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1037 fields->errmsglen = len + 1;
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 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
1040 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1041 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1042
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1043 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1044 * 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
1045 * 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
1046 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1047 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1048 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
1049 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1050 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1051 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1052 *tail = rmp->startp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1053 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1054 }
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 * 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
1058 * 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
1059 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1060 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1061 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
1062 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1063 char_u *match_ptr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1064
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1065 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
1066 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1067 fields->col = 0;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1068 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
1069 ++match_ptr)
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 ++fields->col;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1072 if (*match_ptr == TAB)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1073 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1074 fields->col += 7;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1075 fields->col -= fields->col % 8;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1076 }
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 ++fields->col;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1079 fields->use_viscol = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1080 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1081 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1082
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1083 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1084 * 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
1085 * 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
1086 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1087 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1088 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
1089 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1090 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1091 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1092 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
1093 fields->use_viscol = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1094 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1095 }
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 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1098 * 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
1099 * 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
1100 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1101 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1102 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
1103 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1104 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1105
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1106 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
1107 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1108 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
1109 if (len > CMDBUFFSIZE - 5)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1110 len = CMDBUFFSIZE - 5;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1111 STRCPY(fields->pattern, "^\\V");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1112 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
1113 fields->pattern[len + 3] = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1114 fields->pattern[len + 4] = '$';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1115 fields->pattern[len + 5] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1116 return QF_OK;
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
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1119 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1120 * 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
1121 * 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
1122 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1123 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1124 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
1125 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1126 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1127
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1128 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
1129 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1130 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
1131 if (len > CMDBUFFSIZE)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1132 len = CMDBUFFSIZE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1133 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
1134 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1135 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1136
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1137 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1138 * 'errorformat' format pattern parser functions.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1139 * 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
1140 * 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
1141 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1142 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
1143 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1144 NULL,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1145 qf_parse_fmt_n,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1146 qf_parse_fmt_l,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1147 qf_parse_fmt_c,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1148 qf_parse_fmt_t,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1149 qf_parse_fmt_m,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1150 NULL,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1151 qf_parse_fmt_p,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1152 qf_parse_fmt_v,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1153 qf_parse_fmt_s,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1154 qf_parse_fmt_o
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1155 };
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1156
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1157 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1158 * 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
1159 * "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
1160 * 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
1161 * 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
1162 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1163 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1164 qf_parse_match(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1165 char_u *linebuf,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1166 int linelen,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1167 efm_T *fmt_ptr,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1168 regmatch_T *regmatch,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1169 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1170 int qf_multiline,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1171 int qf_multiscan,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1172 char_u **tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1173 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1174 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
1175 int i;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1176 int midx;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1177 int status;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1178
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1179 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
1180 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1181 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
1182 fields->type = idx;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1183 else
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1184 fields->type = 0;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1185
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1186 // 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
1187 // 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
1188 // 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
1189 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
1190 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1191 status = QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1192 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
1193 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
1194 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
1195 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
1196 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1197 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
1198 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
1199 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
1200 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
1201 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1202 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
1203 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
1204 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
1205 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
1206
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1207 if (status != QF_OK)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1208 return status;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1209 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1210
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1211 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1212 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1213
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1214 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1215 * 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
1216 * '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
1217 * 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
1218 * 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
1219 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1220 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1221 qf_parse_get_fields(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1222 char_u *linebuf,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1223 int linelen,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1224 efm_T *fmt_ptr,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1225 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1226 int qf_multiline,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1227 int qf_multiscan,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1228 char_u **tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1229 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1230 regmatch_T regmatch;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1231 int status = QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1232 int r;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1233
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1234 if (qf_multiscan &&
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1235 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
1236 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1237
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1238 fields->namebuf[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1239 fields->module[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1240 fields->pattern[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1241 if (!qf_multiscan)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1242 fields->errmsg[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1243 fields->lnum = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1244 fields->col = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1245 fields->use_viscol = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1246 fields->enr = -1;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1247 fields->type = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1248 *tail = NULL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1249
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1250 // 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
1251 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
1252 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
1253 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
1254 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
1255 if (r)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1256 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
1257 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
1258
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1259 return status;
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 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
1264 * 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
1265 * names.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1266 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1267 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1268 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
1269 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1270 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
1271 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1272 if (*fields->namebuf == NUL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1273 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1274 EMSG(_("E379: Missing or empty directory name"));
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1275 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1276 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1277 qfl->qf_directory =
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1278 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
1279 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
1280 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1281 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1282 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
1283 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
1284
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1285 return QF_OK;
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 * 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
1290 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1291 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1292 qf_parse_file_pfx(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1293 int idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1294 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1295 qf_list_T *qfl,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1296 char_u *tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1297 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1298 fields->valid = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1299 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
1300 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1301 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
1302 qfl->qf_currfile =
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1303 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
1304 else if (idx == 'Q')
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1305 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
1306 *fields->namebuf = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1307 if (tail && *tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1308 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1309 STRMOVE(IObuff, skipwhite(tail));
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1310 qfl->qf_multiscan = TRUE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1311 return QF_MULTISCAN;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1312 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1313 }
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 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
1320 * format in 'efm').
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1321 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1322 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1323 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
1324 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1325 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1326
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1327 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
1328 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
1329 fields->valid = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1330 if (linelen >= fields->errmsglen)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1331 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1332 // linelen + null terminator
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1333 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
1334 return QF_NOMEM;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1335 fields->errmsg = p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1336 fields->errmsglen = linelen + 1;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1337 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1338 // 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
1339 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
1340
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1341 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1342 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1343
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1344 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1345 * 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
1346 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1347 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1348 qf_parse_multiline_pfx(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1349 qf_info_T *qi,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1350 int qf_idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1351 int idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1352 qf_list_T *qfl,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1353 qffields_T *fields)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1354 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1355 char_u *ptr;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1356 int len;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1357
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1358 if (!qfl->qf_multiignore)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1359 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1360 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
1361
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1362 if (qfprev == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1363 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1364 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
1365 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1366 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
1367 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
1368 == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1369 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1370 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
1371 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
1372 qfprev->qf_text = ptr;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1373 *(ptr += len) = '\n';
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1374 STRCPY(++ptr, fields->errmsg);
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 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
1377 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
1378 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
1379 // 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
1380 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
1381
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1382 if (!qfprev->qf_lnum)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1383 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
1384 if (!qfprev->qf_col)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1385 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
1386 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
1387 if (!qfprev->qf_fnum)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1388 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
1389 qfl->qf_directory,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1390 *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
1391 ? fields->namebuf
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1392 : 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
1393 ? qfl->qf_currfile : 0);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1394 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1395 if (idx == 'Z')
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1396 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
1397 line_breakcheck();
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1398
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1399 return QF_IGNORE_LINE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1400 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1401
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1402 /*
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1403 * 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
1404 * Return the QF_ status.
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1405 */
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1406 static int
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1407 qf_parse_line(
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1408 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
1409 int qf_idx,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1410 char_u *linebuf,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1411 int linelen,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1412 efm_T *fmt_first,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1413 qffields_T *fields)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1414 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1415 efm_T *fmt_ptr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1416 int idx = 0;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1417 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
1418 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
1419 int status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1420
13612
89223f5d5d12 patch 8.0.1678: errorformat "%r" implies "%>"
Christian Brabandt <cb@256bit.org>
parents: 13594
diff changeset
1421 restofline:
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1422 // 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
1423 if (fmt_start == NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1424 fmt_ptr = fmt_first;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1425 else
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1426 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1427 // 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
1428 fmt_ptr = fmt_start;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1429 fmt_start = NULL;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1430 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1431
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1432 // 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
1433 // match or no match.
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1434 fields->valid = TRUE;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1435 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
1436 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1437 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
1438 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
1439 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
1440 if (status == QF_NOMEM)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1441 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1442 if (status == QF_OK)
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1443 break;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1444 }
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
1445 qfl->qf_multiscan = FALSE;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1446
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1447 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
1448 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1449 if (fmt_ptr != NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1450 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1451 // '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
1452 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
1453 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1454 return status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1455 }
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1456
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1457 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
1458 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1459 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1460
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1461 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
1462 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
1463 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1464 else if (fmt_ptr != NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1465 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1466 // honor %> item
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1467 if (fmt_ptr->conthere)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1468 fmt_start = fmt_ptr;
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 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
1471 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1472 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
1473 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
1474 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1475 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
1476 { // 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
1477 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
1478 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1479 return status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1480 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1481 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
1482 { // global file names
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1483 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
1484 if (status == QF_MULTISCAN)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1485 goto restofline;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1486 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1487 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
1488 {
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
1489 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
1490 // 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
1491 qfl->qf_multiignore = TRUE;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1492 return QF_IGNORE_LINE;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1493 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1494 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1495
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1496 return QF_OK;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1497 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1498
9033
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
1499 /*
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1500 * 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
1501 */
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1502 static int
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1503 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
1504 {
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1505 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
1506 }
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1507
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1508 /*
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1509 * 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
1510 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1511 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1512 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
1513 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1514 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
1515 return TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1516 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
1517 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1518
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1519 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1520 * 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
1521 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1522 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1523 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
1524 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1525 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
1526 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
1527 pfields->errmsglen = CMDBUFFSIZE + 1;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1528 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
1529 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
1530 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
1531 || 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
1532 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1533
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1534 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1535 }
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 /*
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1538 * 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
1539 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1540 static void
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1541 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
1542 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1543 vim_free(pfields->namebuf);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1544 vim_free(pfields->module);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1545 vim_free(pfields->errmsg);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1546 vim_free(pfields->pattern);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1547 }
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 /*
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1550 * 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
1551 * quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1552 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1553 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1554 qf_setup_state(
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1555 qfstate_T *pstate,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1556 char_u *enc,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1557 char_u *efile,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1558 typval_T *tv,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1559 buf_T *buf,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1560 linenr_T lnumfirst,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1561 linenr_T lnumlast)
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 #ifdef FEAT_MBYTE
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1564 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
1565 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
1566 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
1567 #endif
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 (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
1570 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1571 EMSG2(_(e_openerrf), efile);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1572 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1573 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1574
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1575 if (tv != NULL)
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 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
1578 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
1579 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
1580 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
1581 pstate->tv = tv;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1582 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1583 pstate->buf = buf;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1584 pstate->buflnum = lnumfirst;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1585 pstate->lnumlast = lnumlast;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1586
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1587 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1588 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1589
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1590 /*
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1591 * 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
1592 * quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1593 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1594 static void
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1595 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
1596 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1597 if (pstate->fd != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1598 fclose(pstate->fd);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1599
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1600 vim_free(pstate->growbuf);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1601 #ifdef FEAT_MBYTE
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1602 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
1603 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
1604 #endif
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1605 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1606
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1607 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1608 * Read the errorfile "efile" into memory, line by line, building the error
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1609 * list.
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1610 * 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
1611 * 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
1612 * 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
1613 * 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
1614 * Set the title of the list to "qf_title".
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1615 * Return -1 for error, number of errors for success.
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1616 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1617 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1618 qf_init_ext(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1619 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
1620 int qf_idx,
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1621 char_u *efile,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1622 buf_T *buf,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1623 typval_T *tv,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1624 char_u *errorformat,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1625 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
1626 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
1627 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
1628 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
1629 char_u *enc)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1630 {
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
1631 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
1632 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
1633 qffields_T fields;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1634 qfline_T *old_last = NULL;
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1635 int adding = FALSE;
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1636 static efm_T *fmt_first = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1637 char_u *efm;
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1638 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
1639 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
1640 int status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1641
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1642 // 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
1643 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
1644
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1645 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
1646 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
1647 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
1648 (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
1649 lnumfirst, lnumlast) == FAIL))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1650 goto qf_init_end;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1651
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
1652 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
1653 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1654 // make place for a new list
3965
eccae034465b updated for version 7.3.738
Bram Moolenaar <bram@vim.org>
parents: 3949
diff changeset
1655 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
1656 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
1657 }
11609
6f11697fb92c patch 8.0.0687: minor issues related to quickfix
Christian Brabandt <cb@256bit.org>
parents: 11589
diff changeset
1658 else
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1659 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1660 // 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
1661 adding = TRUE;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1662 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
1663 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
1664 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1665
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
1666 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
1667
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1668 // Use the local value of 'errorformat' if it's set.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
1669 if (errorformat == p_efm && tv == NULL && *buf->b_p_efm != NUL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1670 efm = buf->b_p_efm;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1671 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1672 efm = errorformat;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
1673
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1674 // 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
1675 // previously parsed values.
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1676 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
1677 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1678 // 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
1679 VIM_CLEAR(last_efm);
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1680 free_efm_list(&fmt_first);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1681
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1682 // parse the current 'efm'
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1683 fmt_first = parse_efm_option(efm);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1684 if (fmt_first != NULL)
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1685 last_efm = vim_strsave(efm);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1686 }
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1687
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1688 if (fmt_first == NULL) // nothing found
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1689 goto error2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1690
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1691 // 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
1692 // ":make" command, but we still want to read the errorfile then.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1693 got_int = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1694
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1695 // 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
1696 // Try to recognize one of the error formats in each line.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1697 while (!got_int)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1698 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1699 // 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
1700 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
1701 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
1702 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
1703 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
1704 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1705
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
1706 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
1707 fmt_first, &fields);
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1708 if (status == QF_FAIL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1709 goto error2;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1710 if (status == QF_NOMEM)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1711 goto qf_init_end;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1712 if (status == QF_IGNORE_LINE)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1713 continue;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1714
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
1715 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
1716 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
1717 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
1718 (*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
1719 ? 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
1720 : ((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
1721 ? 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
1722 fields.module,
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
1723 0,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1724 fields.errmsg,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1725 fields.lnum,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1726 fields.col,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1727 fields.use_viscol,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1728 fields.pattern,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1729 fields.enr,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1730 fields.type,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1731 fields.valid) == FAIL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1732 goto error2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1733 line_breakcheck();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1734 }
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
1735 if (state.fd == NULL || !ferror(state.fd))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1736 {
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
1737 if (qfl->qf_index == 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1738 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1739 // 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
1740 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
1741 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
1742 qfl->qf_nonevalid = TRUE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1743 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1744 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1745 {
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
1746 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
1747 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
1748 qfl->qf_ptr = qfl->qf_start;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1749 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1750 // 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
1751 retval = qfl->qf_count;
9369
ce5b79b005ec commit https://github.com/vim/vim/commit/bcf7772a23624edc0942120e564f6b4ac95604ad
Christian Brabandt <cb@256bit.org>
parents: 9365
diff changeset
1752 goto qf_init_end;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1753 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1754 EMSG(_(e_readerrf));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1755 error2:
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1756 if (!adding)
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1757 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1758 // 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
1759 qf_free(qfl);
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1760 qi->qf_listcount--;
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1761 if (qi->qf_curlist > 0)
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1762 --qi->qf_curlist;
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1763 }
9369
ce5b79b005ec commit https://github.com/vim/vim/commit/bcf7772a23624edc0942120e564f6b4ac95604ad
Christian Brabandt <cb@256bit.org>
parents: 9365
diff changeset
1764 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
1765 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
1766 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
1767 qf_cleanup_state(&state);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1768 qf_free_fields(&fields);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1769
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1770 return retval;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1771 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1772
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1773 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1774 * 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
1775 * 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
1776 * 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
1777 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1778 int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1779 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
1780 char_u *efile,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1781 char_u *errorformat,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1782 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
1783 char_u *qf_title,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1784 char_u *enc)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1785 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1786 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
1787
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1788 if (wp != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1789 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1790 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
1791 if (qi == NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1792 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1793 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1794
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1795 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
1796 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
1797 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1798
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1799 /*
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1800 * 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
1801 * Prepends ':' to the title.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1802 */
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1803 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
1804 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
1805 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1806 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
1807
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1808 if (title != NULL)
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1809 {
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1810 char_u *p = alloc((int)STRLEN(title) + 2);
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1811
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
1812 qfl->qf_title = p;
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1813 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
1814 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
1815 }
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1816 }
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1817
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1818 /*
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1819 * 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
1820 * 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
1821 * 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
1822 * 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
1823 */
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1824 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
1825 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
1826 {
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1827 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
1828
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1829 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
1830 return qftitle_str;
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1831 }
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1832
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1833 /*
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
1834 * 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
1835 * 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
1836 * the new list is added.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1837 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1838 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1839 qf_new_list(qf_info_T *qi, char_u *qf_title)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1840 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1841 int i;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1842 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1843
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1844 // 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
1845 // 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
1846 // way with ":grep'.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1847 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
1848 qf_free(&qi->qf_lists[--qi->qf_listcount]);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1849
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1850 // 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
1851 // Otherwise, add a new entry.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1852 if (qi->qf_listcount == LISTCOUNT)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1853 {
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
1854 qf_free(&qi->qf_lists[0]);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1855 for (i = 1; i < LISTCOUNT; ++i)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1856 qi->qf_lists[i - 1] = qi->qf_lists[i];
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1857 qi->qf_curlist = LISTCOUNT - 1;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1858 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1859 else
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1860 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
1861 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
1862 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
1863 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
1864 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
1865 qfl->qf_id = ++last_qf_id;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1866 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1867
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1868 /*
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1869 * 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
1870 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1871 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1872 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
1873 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1874 qf_delq_T *q;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1875
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1876 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
1877 if (q != NULL)
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 q->qi = qi;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1880 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
1881 qf_delq_head = q;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1882 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1883 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1884
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1885 /*
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
1886 * Free a location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1887 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1888 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1889 ll_free_all(qf_info_T **pqi)
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1890 {
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1891 int i;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1892 qf_info_T *qi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1893
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1894 qi = *pqi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1895 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1896 return;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1897 *pqi = NULL; // Remove reference to this list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1898
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1899 qi->qf_refcount--;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1900 if (qi->qf_refcount < 1)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1901 {
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1902 // 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
1903 // 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
1904 // to be processed later.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1905 if (quickfix_busy > 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1906 locstack_queue_delreq(qi);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1907 else
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1908 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1909 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
1910 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
1911 vim_free(qi);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1912 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1913 }
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1914 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1915
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1916 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1917 * 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
1918 */
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1919 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1920 qf_free_all(win_T *wp)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1921 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1922 int i;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1923 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1924
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1925 if (wp != NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1926 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1927 // location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1928 ll_free_all(&wp->w_llist);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1929 ll_free_all(&wp->w_llist_ref);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1930 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1931 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1932 // quickfix list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1933 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
1934 qf_free(&qi->qf_lists[i]);
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1935 }
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1936
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1937 /*
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1938 * 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
1939 * 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
1940 * 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
1941 * 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
1942 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1943 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1944 incr_quickfix_busy(void)
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 quickfix_busy++;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1947 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1948
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1949 /*
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1950 * 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
1951 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1952 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1953 decr_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1954 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1955 if (--quickfix_busy == 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1956 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1957 // 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
1958 // delete requests.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1959 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
1960 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1961 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
1962
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1963 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
1964 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
1965 vim_free(q);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1966 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1967 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1968 #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
1969 if (quickfix_busy < 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1970 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1971 EMSG("quickfix_busy has become negative");
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1972 abort();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1973 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1974 #endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1975 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1976
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1977 #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
1978 void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1979 check_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1980 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1981 if (quickfix_busy != 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1982 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1983 EMSGN("quickfix_busy not zero on exit: %ld", (long)quickfix_busy);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1984 # 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
1985 abort();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1986 # endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1987 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1988 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1989 #endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1990
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1991 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1992 * Add an entry to the end of the list of errors.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1993 * Returns OK or FAIL.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1994 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1995 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1996 qf_add_entry(
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1997 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
1998 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
1999 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
2000 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
2001 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
2002 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
2003 char_u *mesg, // message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2004 long lnum, // line number
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2005 int col, // column
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2006 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
2007 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
2008 int nr, // error number
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2009 int type, // type character
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2010 int valid) // valid entry
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2011 {
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
2012 qf_list_T *qfl = &qi->qf_lists[qf_idx];
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2013 qfline_T *qfp;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2014 qfline_T **lastp; // pointer to qf_last or NULL
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2015
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2016 if ((qfp = (qfline_T *)alloc((unsigned)sizeof(qfline_T))) == NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2017 return FAIL;
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
2018 if (bufnum != 0)
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2019 {
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2020 buf_T *buf = buflist_findnr(bufnum);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2021
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
2022 qfp->qf_fnum = bufnum;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2023 if (buf != NULL)
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
2024 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
2025 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
2026 }
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
2027 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
2028 qfp->qf_fnum = qf_get_fnum(qi, qf_idx, dir, fname);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2029 if ((qfp->qf_text = vim_strsave(mesg)) == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2030 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2031 vim_free(qfp);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2032 return FAIL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2033 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2034 qfp->qf_lnum = lnum;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2035 qfp->qf_col = col;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
2036 qfp->qf_viscol = vis_col;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2037 if (pattern == NULL || *pattern == NUL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2038 qfp->qf_pattern = NULL;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2039 else if ((qfp->qf_pattern = vim_strsave(pattern)) == NULL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2040 {
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2041 vim_free(qfp->qf_text);
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2042 vim_free(qfp);
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2043 return FAIL;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2044 }
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2045 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
2046 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
2047 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
2048 {
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2049 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
2050 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
2051 vim_free(qfp);
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2052 return FAIL;
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2053 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2054 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
2055 if (type != 1 && !vim_isprintc(type)) // only printable chars allowed
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2056 type = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2057 qfp->qf_type = type;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2058 qfp->qf_valid = valid;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2059
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
2060 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
2061 if (qf_list_empty(qi, qf_idx)) // first element in the list
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2062 {
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
2063 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
2064 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
2065 qfl->qf_index = 0;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2066 qfp->qf_prev = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2067 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2068 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2069 {
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2070 qfp->qf_prev = *lastp;
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2071 (*lastp)->qf_next = qfp;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2072 }
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2073 qfp->qf_next = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2074 qfp->qf_cleared = FALSE;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2075 *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
2076 ++qfl->qf_count;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2077 if (qfl->qf_index == 0 && qfp->qf_valid) // first valid entry
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2078 {
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
2079 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
2080 qfl->qf_ptr = qfp;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2081 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2082
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2083 return OK;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2084 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2085
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2086 /*
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
2087 * Allocate a new quickfix/location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2088 */
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2089 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
2090 qf_alloc_stack(qfltype_T qfltype)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2091 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2092 qf_info_T *qi;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2093
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
2094 qi = (qf_info_T *)alloc_clear((unsigned)sizeof(qf_info_T));
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2095 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
2096 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2097 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
2098 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
2099 }
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2100 return qi;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2101 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2102
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2103 /*
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
2104 * 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
2105 * If not present, allocate a location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2106 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2107 static qf_info_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2108 ll_get_or_alloc_list(win_T *wp)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2109 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2110 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
2111 // For a location list window, use the referenced location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2112 return wp->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2113
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2114 // 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
2115 // location list.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2116 ll_free_all(&wp->w_llist_ref);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2117
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2118 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
2119 wp->w_llist = qf_alloc_stack(QFLT_LOCATION); // new location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2120 return wp->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2121 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2122
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2123 /*
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2124 * 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
2125 */
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2126 static int
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2127 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
2128 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2129 int i;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2130 qfline_T *from_qfp;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2131 qfline_T *prevp;
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 // 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
2134 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
2135 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
2136 ++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
2137 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2138 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
2139 to_qi->qf_curlist,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2140 NULL,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2141 NULL,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2142 from_qfp->qf_module,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2143 0,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2144 from_qfp->qf_text,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2145 from_qfp->qf_lnum,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2146 from_qfp->qf_col,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2147 from_qfp->qf_viscol,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2148 from_qfp->qf_pattern,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2149 from_qfp->qf_nr,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2150 0,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2151 from_qfp->qf_valid) == FAIL)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2152 return FAIL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2153
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2154 // 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
2155 // 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
2156 // field is copied here.
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2157 prevp = to_qfl->qf_last;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2158 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
2159 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
2160 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
2161 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
2162 }
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 return OK;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2165 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2166
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 * 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
2169 */
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2170 static int
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2171 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
2172 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2173 // 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
2174 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
2175 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
2176 to_qfl->qf_count = 0;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2177 to_qfl->qf_index = 0;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2178 to_qfl->qf_start = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2179 to_qfl->qf_last = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2180 to_qfl->qf_ptr = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2181 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
2182 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
2183 else
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2184 to_qfl->qf_title = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2185 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
2186 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2187 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
2188 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
2189 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
2190 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2191 else
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2192 to_qfl->qf_ctx = NULL;
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 if (from_qfl->qf_count)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2195 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
2196 return FAIL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2197
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2198 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
2199
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2200 // 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
2201 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
2202 to_qfl->qf_changedtick = 0L;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2203
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2204 // 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
2205 // 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
2206 if (to_qfl->qf_nonevalid)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2207 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2208 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
2209 to_qfl->qf_index = 1;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2210 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2211
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2212 return OK;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2213 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2214
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2215 /*
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2216 * Copy the location list stack 'from' window to 'to' window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2217 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2218 void
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2219 copy_loclist_stack(win_T *from, win_T *to)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2220 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2221 qf_info_T *qi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2222 int idx;
14844
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 // 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
2225 // 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
2226 // that window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2227 if (IS_LL_WINDOW(from))
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2228 qi = from->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2229 else
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2230 qi = from->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2231
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2232 if (qi == NULL) // no location list to copy
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2233 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2234
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2235 // 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
2236 if ((to->w_llist = qf_alloc_stack(QFLT_LOCATION)) == NULL)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2237 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2238
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2239 to->w_llist->qf_listcount = qi->qf_listcount;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2240
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2241 // 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
2242 for (idx = 0; idx < qi->qf_listcount; ++idx)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2243 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2244 to->w_llist->qf_curlist = idx;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2245
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2246 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
2247 &to->w_llist->qf_lists[idx], to->w_llist) == FAIL)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2248 {
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2249 qf_free_all(to);
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2250 return;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2251 }
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2252 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2253
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2254 to->w_llist->qf_curlist = qi->qf_curlist; // current list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2255 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2256
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2257 /*
10379
73e2a7abe2a3 commit https://github.com/vim/vim/commit/7618e00d3b8bfe064cfc524640d754607361f9df
Christian Brabandt <cb@256bit.org>
parents: 10369
diff changeset
2258 * 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
2259 * Also sets the b_has_qf_entry flag.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2260 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2261 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
2262 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
2263 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
2264 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
2265 char_u *ptr = NULL;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2266 buf_T *buf;
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2267 char_u *bufname;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2268
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2269 if (fname == NULL || *fname == NUL) // no file name
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2270 return 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2271
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2272 #ifdef VMS
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2273 vms_remove_version(fname);
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2274 #endif
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2275 #ifdef BACKSLASH_IN_FILENAME
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2276 if (directory != NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2277 slash_adjust(directory);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2278 slash_adjust(fname);
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2279 #endif
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2280 if (directory != NULL && !vim_isAbsName(fname)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2281 && (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
2282 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2283 // 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
2284 // 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
2285 // "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
2286 // directory change.
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2287 if (mch_getperm(ptr) < 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2288 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2289 vim_free(ptr);
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
2290 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
2291 if (directory)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2292 ptr = concat_fnames(directory, fname, TRUE);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2293 else
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2294 ptr = vim_strsave(fname);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2295 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2296 // 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
2297 bufname = ptr;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2298 }
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2299 else
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2300 bufname = fname;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2301
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2302 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
2303 && bufref_valid(&qf_last_bufref))
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2304 {
9475
4d8f7f8da90c commit https://github.com/vim/vim/commit/b25f9a97e9aad3cbb4bc3fe87cdbd5700f8aa0c6
Christian Brabandt <cb@256bit.org>
parents: 9473
diff changeset
2305 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
2306 vim_free(ptr);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2307 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2308 else
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2309 {
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2310 vim_free(qf_last_bufname);
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2311 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
2312 if (bufname == ptr)
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2313 qf_last_bufname = bufname;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2314 else
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2315 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
2316 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
2317 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2318 if (buf == NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2319 return 0;
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2320
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
2321 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
2322 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
2323 return buf->b_fnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2324 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2325
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2326 /*
9334
674f9e3ccd1a commit https://github.com/vim/vim/commit/38df43bd13a2498cc96b3ddd9a20dd75126bd171
Christian Brabandt <cb@256bit.org>
parents: 9201
diff changeset
2327 * 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
2328 * NULL on error.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2329 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2330 static char_u *
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
2331 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
2332 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2333 struct dir_stack_T *ds_new;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2334 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2335
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2336 // allocate new stack element and hook it in
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2337 ds_new = (struct dir_stack_T *)alloc((unsigned)sizeof(struct dir_stack_T));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2338 if (ds_new == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2339 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2340
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2341 ds_new->next = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2342 *stackptr = ds_new;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2343
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2344 // store directory on the stack
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2345 if (vim_isAbsName(dirbuf)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2346 || (*stackptr)->next == NULL
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
2347 || (*stackptr && is_file_stack))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2348 (*stackptr)->dirname = vim_strsave(dirbuf);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2349 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2350 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2351 // 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
2352 // 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
2353 // Let's search...
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2354 ds_new = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2355 (*stackptr)->dirname = NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2356 while (ds_new)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2357 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2358 vim_free((*stackptr)->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2359 (*stackptr)->dirname = concat_fnames(ds_new->dirname, dirbuf,
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2360 TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2361 if (mch_isdir((*stackptr)->dirname) == TRUE)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2362 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2363
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2364 ds_new = ds_new->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2365 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2366
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2367 // clean up all dirs we already left
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2368 while ((*stackptr)->next != ds_new)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2369 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2370 ds_ptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2371 (*stackptr)->next = (*stackptr)->next->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2372 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2373 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2374 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2375
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2376 // Nothing found -> it must be on top level
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2377 if (ds_new == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2378 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2379 vim_free((*stackptr)->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2380 (*stackptr)->dirname = vim_strsave(dirbuf);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2381 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2382 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2383
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2384 if ((*stackptr)->dirname != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2385 return (*stackptr)->dirname;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2386 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2387 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2388 ds_ptr = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2389 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2390 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2391 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2392 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2393 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2394
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2395 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2396 * pop dirbuf from the directory stack and return previous directory or NULL if
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2397 * stack is empty
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2398 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2399 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2400 qf_pop_dir(struct dir_stack_T **stackptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2401 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2402 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2403
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2404 // 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
2405 // 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
2406
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2407 // pop top element and free it
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2408 if (*stackptr != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2409 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2410 ds_ptr = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2411 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2412 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2413 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2414 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2415
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2416 // return NEW top element as current dir or NULL if stack is empty
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2417 return *stackptr ? (*stackptr)->dirname : NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2418 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2419
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2420 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2421 * clean up directory stack
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2422 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2423 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2424 qf_clean_dir_stack(struct dir_stack_T **stackptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2425 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2426 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2427
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2428 while ((ds_ptr = *stackptr) != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2429 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2430 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2431 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2432 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2433 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2434 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2435
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2436 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2437 * Check in which directory of the directory stack the given file can be
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2438 * found.
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
2439 * Returns a pointer to the directory name or NULL if not found.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2440 * Cleans up intermediate directory entries.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2441 *
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2442 * 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
2443 * If we have this directory tree:
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2444 * ./
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2445 * ./aa
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2446 * ./aa/bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2447 * ./bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2448 * ./bb/x.c
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2449 * and make says:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2450 * making all in aa
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2451 * making all in bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2452 * x.c:9: Error
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2453 * 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
2454 * qf_guess_filepath will return NULL.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2455 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2456 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
2457 qf_guess_filepath(qf_list_T *qfl, char_u *filename)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2458 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2459 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2460 struct dir_stack_T *ds_tmp;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2461 char_u *fullname;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2462
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2463 // 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
2464 if (qfl->qf_dir_stack == NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2465 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2466
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
2467 ds_ptr = qfl->qf_dir_stack->next;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2468 fullname = NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2469 while (ds_ptr)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2470 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2471 vim_free(fullname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2472 fullname = concat_fnames(ds_ptr->dirname, filename, TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2473
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2474 // 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
2475 // is that we delete the entire stack.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2476 if ((fullname != NULL) && (mch_getperm(fullname) >= 0))
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2477 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2478
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2479 ds_ptr = ds_ptr->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2480 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2481
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2482 vim_free(fullname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2483
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2484 // 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
2485 while (qfl->qf_dir_stack->next != ds_ptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2486 {
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
2487 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
2488 qfl->qf_dir_stack->next = qfl->qf_dir_stack->next->next;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2489 vim_free(ds_tmp->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2490 vim_free(ds_tmp);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2491 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2492
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
2493 return ds_ptr == NULL ? NULL : ds_ptr->dirname;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2494 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2495
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2496 /*
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2497 * 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
2498 */
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2499 static int
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
2500 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
2501 {
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2502 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
2503 int i;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2504
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2505 if (wp != NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
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 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
2508 if (qi == NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2509 return FALSE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2510 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2511
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2512 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
2513 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
2514 return TRUE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2515
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2516 return FALSE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2517 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2518
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2519 /*
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
2520 * 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
2521 * 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
2522 * 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
2523 * Similar to location list.
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2524 */
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2525 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
2526 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
2527 {
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2528 qfline_T *qfp;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2529 int i;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2530
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2531 // 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
2532 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
2533 ++i, qfp = qfp->qf_next)
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2534 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
2535 break;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2536
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2537 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
2538 return FALSE;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2539
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2540 return TRUE;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2541 }
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2542
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2543 /*
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2544 * 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
2545 * 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_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
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 {
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
2562 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
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_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
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 == 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
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 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
2575 * 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
2576 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2577 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2578 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
2579 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
2580 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
2581 int *qf_index,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2582 int dir)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2583 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2584 int idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2585 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
2586
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2587 idx = *qf_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2588 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
2589
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2590 do
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2591 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2592 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
2593 return NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2594 --idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2595 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
2596 } 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
2597 || (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
2598
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2599 *qf_index = idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2600 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2601 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2602
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 * 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
2605 * the quickfix list.
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2606 * 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
2607 * 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
2608 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2609 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2610 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
2611 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
2612 int errornr,
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2613 int dir,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2614 int *new_qfidx)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2615 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2616 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
2617 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
2618 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
2619 int prev_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2620 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
2621 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
2622
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2623 while (errornr--)
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 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
2626 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
2627
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2628 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
2629 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
2630 else
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2631 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
2632 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
2633 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2634 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
2635 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
2636 if (err != NULL)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2637 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2638 EMSG(_(err));
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2639 return NULL;
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 break;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2642 }
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 err = NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2645 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2646
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2647 *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
2648 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2649 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2650
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2651 /*
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2652 * 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
2653 * 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
2654 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2655 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
2656 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
2657 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2658 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
2659 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
2660
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2661 // 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
2662 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
2663 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2664 --qf_idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2665 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
2666 }
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2667 // 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
2668 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
2669 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
2670 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2671 ++qf_idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2672 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
2673 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2674
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2675 *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
2676 return qf_ptr;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2677 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2678
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2679 /*
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2680 * 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
2681 * 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
2682 * 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
2683 * 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
2684 * 'new_qfidx'.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2685 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2686 static qfline_T *
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2687 qf_get_entry(
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2688 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
2689 int errornr,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2690 int dir,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2691 int *new_qfidx)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2692 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2693 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
2694 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
2695
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2696 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
2697 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
2698 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
2699 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
2700
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2701 *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
2702 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2703 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2704
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2705 /*
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
2706 * 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
2707 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2708 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
2709 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
2710 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2711 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
2712
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2713 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
2714 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
2715 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
2716
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2717 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
2718 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2719
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2720 /*
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2721 * 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
2722 * window.
12449
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 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
2725 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
2726 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2727 win_T *wp;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2728 int flags;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2729
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2730 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
2731 wp = NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2732 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
2733 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
2734 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
2735 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
2736 else
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2737 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2738 // 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
2739 // 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
2740 flags = WSP_HELP;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2741 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
2742 && 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
2743 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
2744 // 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
2745 // 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
2746 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
2747 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
2748
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2749 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
2750 return FAIL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2751
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2752 *opened_window = TRUE;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2753
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2754 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
2755 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
2756
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2757 // 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
2758 // 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
2759 // 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
2760 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
2761 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2762 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
2763 qi->qf_refcount++;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2764 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2765 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2766
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2767 if (!p_im)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2768 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
2769
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2770 return OK;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2771 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2772
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2773 /*
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
2774 * 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
2775 * 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
2776 */
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 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
2778 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
2779 {
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 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
2781
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 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
2783 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
2784 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
2785
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 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
2787 }
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
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 * 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
2791 */
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 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
2793 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
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 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
2796
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 FOR_ALL_WINDOWS(wp)
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2798 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
2799 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
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 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
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
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 /*
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 * 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
2806 * 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
2807 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2808 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
2809 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
2810 {
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 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
2812 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
2813
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2814 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
2815 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
2816 {
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 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
2818 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
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 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
2822 }
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
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 /*
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 * 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
2826 * 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
2827 */
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 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
2829 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
2830 {
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 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
2832
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 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
2834 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
2835 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
2836 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
2837 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
2838 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
2839 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
2840 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
2841 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
2842 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2843 // 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
2844 // 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
2845 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
2846 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
2847 }
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 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
2849 }
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
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 * 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
2853 * 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
2854 * 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
2855 * 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
2856 */
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 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
2858 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
2859 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2860 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
2861
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 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
2863 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2864 // 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
2865 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
2866 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
2867 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
2868 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
2869 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2870 // 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
2871 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
2872 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
2873 {
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2874 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
2875 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
2876 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
2877 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
2878 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2879 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
2880 } 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
2881 }
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 }
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 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
2884
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2885 // 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
2886 // 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
2887 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
2888 {
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 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
2890 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
2891 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
2892 }
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 }
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
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 /*
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
2896 * 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
2897 * 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
2898 * 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
2899 * 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
2900 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2901 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
2902 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
2903 {
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 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
2905 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
2906
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 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
2908 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
2909 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
2910 {
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 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
2912 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
2913 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
2914 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
2915 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2916 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
2917
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2918 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
2919 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2920 // 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
2921 // 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
2922 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
2923 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
2924 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
2925 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
2926 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
2927 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
2928 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
2929 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2930
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2931 // Remember a usable window.
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2932 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
2933 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
2934 }
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
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 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
2937 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2938
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2939 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2940 * 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
2941 * 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
2942 * 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
2943 * '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
2944 * 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
2945 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2946 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
2947 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
2948 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2949 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
2950 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
2951 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
2952 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
2953
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2954 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
2955
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2956 // 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
2957 // 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
2958 // location list.
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2959 if (!newwin)
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
2960 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
2961
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2962 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
2963 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2964 // 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
2965 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
2966 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
2967 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
2968 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2969
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2970 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
2971 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2972 // 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
2973 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
2974 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
2975 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
2976 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2977
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2978 // 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
2979 // 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
2980 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
2981 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
2982
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2983 // 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
2984 // 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
2985 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
2986 {
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
2987 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
2988 return FAIL;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2989 *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
2990 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2991 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2992 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2993 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
2994 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
2995 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
2996 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
2997 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2998
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2999 return OK;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3000 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3001
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3002 /*
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3003 * 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
3004 * 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
3005 * 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
3006 * 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
3007 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3008 static int
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3009 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
3010 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
3011 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
3012 int forceit,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3013 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
3014 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
3015 {
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
3016 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
3017 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
3018 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
3019 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
3020 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
3021
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3022 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
3023 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3024 // 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
3025 // 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
3026 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
3027 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3028 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
3029 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
3030 }
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3031
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3032 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
3033 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
3034 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
3035 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3036 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3037 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
3038 (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
3039
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3040 // 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
3041 // present.
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
3042 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
3043 {
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3044 EMSG(_("E924: Current window was closed"));
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3045 *opened_window = FALSE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3046 return NOTDONE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3047 }
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3048
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
3049 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
3050 {
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3051 EMSG(_("E925: Current quickfix was changed"));
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3052 return NOTDONE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3053 }
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3054
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3055 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
3056 || !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
3057 {
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
3058 if (qfl_type == QFLT_QUICKFIX)
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3059 EMSG(_("E925: Current quickfix was changed"));
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3060 else
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3061 EMSG(_(e_loc_list_changed));
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3062 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
3063 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3064
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3065 return retval;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3066 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3067
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3068 /*
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
3069 * 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
3070 * 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
3071 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3072 static void
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3073 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
3074 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
3075 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
3076 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
3077 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
3078 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3079 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
3080 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
3081 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
3082 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
3083
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3084 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
3085 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3086 // 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
3087 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
3088 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
3089 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3090 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
3091 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
3092 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
3093 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3094 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
3095 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3096 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
3097 #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
3098 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
3099 #endif
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3100 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
3101 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3102 // 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
3103 // 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
3104 // 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
3105 // 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
3106 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
3107 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
3108 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
3109 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3110 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
3111 break;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3112 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
3113 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3114 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
3115 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
3116 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3117 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3118 ++screen_col;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3119 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3120 }
14552
b298737a7188 patch 8.1.0289: cursor moves to wrong column after quickfix jump
Christian Brabandt <cb@256bit.org>
parents: 14550
diff changeset
3121 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
3122 check_cursor();
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3123 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3124 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3125 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
3126 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3127 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3128 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3129 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
3130
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3131 // 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
3132 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
3133 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
3134 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
3135 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
3136 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
3137 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3138 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3139
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3140 /*
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3141 * 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
3142 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3143 static void
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3144 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
3145 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
3146 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
3147 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
3148 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
3149 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
3150 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3151 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
3152 int len;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3153
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3154 // 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
3155 // 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
3156 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
3157 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
3158 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
3159 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
3160 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
3161 (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
3162 // 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
3163 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
3164 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
3165
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3166 // 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
3167 // 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
3168 // 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
3169 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
3170 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
3171 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
3172 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
3173 msg_scroll = FALSE;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3174 msg_attr_keep(IObuff, 0, TRUE);
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3175 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
3176 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3177
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3178 /*
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3179 * 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
3180 * 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
3181 * 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
3182 * 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
3183 * 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
3184 * with the entry.
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 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
3187 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
3188 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
3189 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
3190 int newwin,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3191 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
3192 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3193 // 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
3194 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
3195 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
3196 return FAIL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3197
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3198 // 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
3199 // file in.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3200 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
3201 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3202 // 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
3203 // 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
3204 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
3205 return NOTDONE;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3206
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3207 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
3208 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
3209 return FAIL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3210 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3211
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3212 return OK;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3213 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3214
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3215 /*
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3216 * 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
3217 * 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
3218 * jump.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3219 * 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
3220 * 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
3221 * the file.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3222 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3223 static int
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3224 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
3225 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
3226 int qf_index,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3227 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
3228 int forceit,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3229 win_T *oldwin,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3230 int *opened_window,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3231 int openfold,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3232 int print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3233 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3234 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
3235 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
3236 int retval = OK;
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 // 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
3239 // autowrite etc.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3240 old_curbuf = curbuf;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3241 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
3242
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3243 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
3244 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3245 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
3246 opened_window);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3247 if (retval != OK)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3248 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3249 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3250
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3251 // 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
3252 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
3253 setpcmark();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3254
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3255 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
3256 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
3257
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3258 #ifdef FEAT_FOLDING
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3259 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
3260 foldOpenCursor();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3261 #endif
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3262 if (print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3263 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
3264
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3265 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3266 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3267
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3268 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3269 * Jump to a quickfix line and try to use an existing window.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3270 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3271 void
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3272 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
3273 int dir,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3274 int errornr,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3275 int forceit)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3276 {
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3277 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
3278 }
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3279
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3280 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
3281 * 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
3282 * 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
3283 * 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
3284 * 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
3285 * 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
3286 * 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
3287 * 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
3288 * 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
3289 * 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
3290 */
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3291 void
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3292 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
3293 int dir,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3294 int errornr,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3295 int forceit,
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3296 int newwin)
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3297 {
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
3298 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3299 qfline_T *qf_ptr;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3300 qfline_T *old_qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3301 int qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3302 int old_qf_index;
639
c79d4df4686e updated for version 7.0185
vimboss
parents: 634
diff changeset
3303 char_u *old_swb = p_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3304 unsigned old_swb_flags = swb_flags;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3305 int opened_window = FALSE;
1743
734d5bdae499 updated for version 7.2-041
vimboss
parents: 1683
diff changeset
3306 win_T *oldwin = curwin;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3307 int print_message = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3308 #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
3309 int old_KeyTyped = KeyTyped; // getting file may reset it
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3310 #endif
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3311 int retval = OK;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3312
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3313 if (qi == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3314 qi = &ql_info;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3315
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3316 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3317 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3318 EMSG(_(e_quickfix));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3319 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3320 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3321
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
3322 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
3323
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3324 qf_ptr = qfl->qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3325 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
3326 qf_index = qfl->qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3327 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
3328
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3329 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
3330 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
3331 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3332 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
3333 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
3334 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3335 }
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
3336
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3337 qfl->qf_index = qf_index;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3338 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
3339 // 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
3340 // window
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3341 print_message = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3342
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3343 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
3344 if (retval == FAIL)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3345 goto failed;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3346 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3347 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3348
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3349 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
3350 &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
3351 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3352 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3353 // 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
3354 qi = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3355 qf_ptr = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3356 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3357
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3358 if (retval != OK)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3359 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3360 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
3361 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
3362 if (qf_ptr != NULL && qf_ptr->qf_fnum != 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3363 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3364 // 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
3365 // happen if the file was readonly and we changed something.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3366 failed:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3367 qf_ptr = old_qf_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3368 qf_index = old_qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3369 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3370 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3371 theend:
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3372 if (qi != NULL)
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3373 {
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
3374 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
3375 qfl->qf_index = qf_index;
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3376 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3377 if (p_swb != old_swb && opened_window)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3378 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3379 // 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
3380 // modeline has changed the value.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3381 if (p_swb == empty_option)
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3382 {
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3383 p_swb = old_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3384 swb_flags = old_swb_flags;
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3385 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3386 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3387 free_string_option(old_swb);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3388 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3389 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3390
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3391 // 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
3392 static int qfFileAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3393 static int qfSepAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3394 static int qfLineAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3395
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 * 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
3398 * 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
3399 * '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
3400 * quickfix list.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3401 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3402 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
3403 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
3404 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3405 char_u *fname;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3406 buf_T *buf;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3407 int filter_entry;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3408
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3409 fname = NULL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3410 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
3411 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
3412 (char *)qfp->qf_module);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3413 else {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3414 if (qfp->qf_fnum != 0
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3415 && (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
3416 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3417 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
3418 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
3419 fname = gettail(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3420 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3421 if (fname == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3422 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
3423 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3424 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
3425 qf_idx, (char *)fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3426 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3427
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3428 // 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
3429 // 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
3430 // text of the entry.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3431 filter_entry = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3432 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
3433 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
3434 if (filter_entry && fname != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3435 filter_entry &= message_filtered(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3436 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
3437 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
3438 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3439 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
3440 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3441 return;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3442
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3443 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
3444 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
3445
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3446 if (qfp->qf_lnum != 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3447 msg_puts_attr((char_u *)":", qfSepAttr);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3448 if (qfp->qf_lnum == 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3449 IObuff[0] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3450 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
3451 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
3452 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3453 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
3454 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
3455 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
3456 (char *)qf_types(qfp->qf_type, qfp->qf_nr));
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3457 msg_puts_attr(IObuff, qfLineAttr);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3458 msg_puts_attr((char_u *)":", qfSepAttr);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3459 if (qfp->qf_pattern != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3460 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3461 qf_fmt_text(qfp->qf_pattern, IObuff, IOSIZE);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3462 msg_puts(IObuff);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3463 msg_puts_attr((char_u *)":", qfSepAttr);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3464 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3465 msg_puts((char_u *)" ");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3466
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3467 // 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
3468 // 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
3469 // with ^^^^.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3470 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
3471 ? 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
3472 IObuff, IOSIZE);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3473 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
3474 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
3475 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3476
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3477 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3478 * ":clist": list all errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3479 * ":llist": list all locations
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3480 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3481 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3482 qf_list(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3483 {
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
3484 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3485 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3486 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3487 int idx1 = 1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3488 int idx2 = -1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3489 char_u *arg = eap->arg;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3490 int plus = FALSE;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3491 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
3492 // recognised errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3493 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3494
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3495 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3496 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3497 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3498 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3499 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3500 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3501 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3502 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3503 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3504
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3505 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3506 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3507 EMSG(_(e_quickfix));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3508 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3509 }
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3510 if (*arg == '+')
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3511 {
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3512 ++arg;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3513 plus = TRUE;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3514 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3515 if (!get_list_range(&arg, &idx1, &idx2) || *arg != NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3516 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3517 EMSG(_(e_trailing));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3518 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3519 }
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
3520 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
3521 if (plus)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3522 {
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 i = qfl->qf_index;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3524 idx2 = i + idx1;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3525 idx1 = i;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3526 }
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3527 else
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3528 {
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
3529 i = qfl->qf_count;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3530 if (idx1 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3531 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
3532 if (idx2 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3533 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
3534 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3535
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3536 // 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
3537 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
3538
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3539 // 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
3540 // 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
3541 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
3542 if (qfFileAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3543 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
3544 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
3545 if (qfSepAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3546 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
3547 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
3548 if (qfLineAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3549 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
3550
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
3551 if (qfl->qf_nonevalid)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3552 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
3553 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
3554 for (i = 1; !got_int && i <= qfl->qf_count; )
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3555 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3556 if ((qfp->qf_valid || all) && idx1 <= i && i <= idx2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3557 {
2047
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3558 if (got_int)
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3559 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3560
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
3561 qf_list_entry(qfp, i, i == qfl->qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3562 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3563
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3564 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3565 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3566 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3567 ++i;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3568 ui_breakcheck();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3569 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3570 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3571
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3572 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3573 * Remove newlines and leading whitespace from an error message.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3574 * Put the result in "buf[bufsize]".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3575 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3576 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3577 qf_fmt_text(char_u *text, char_u *buf, int bufsize)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3578 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3579 int i;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3580 char_u *p = text;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3581
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3582 for (i = 0; *p != NUL && i < bufsize - 1; ++i)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3583 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3584 if (*p == '\n')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3585 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3586 buf[i] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3587 while (*++p != NUL)
11129
f4ea50924c6d patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents: 11063
diff changeset
3588 if (!VIM_ISWHITE(*p) && *p != '\n')
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3589 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3590 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3591 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3592 buf[i] = *p++;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3593 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3594 buf[i] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3595 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3596
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3597 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3598 * 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
3599 * quickfix/location list.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3600 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3601 static void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3602 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
3603 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3604 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
3605 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
3606 char_u buf[IOSIZE];
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3607
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3608 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
3609 lead,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3610 which + 1,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3611 qi->qf_listcount,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3612 count);
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3613
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3614 if (title != NULL)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3615 {
9579
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3616 size_t len = STRLEN(buf);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3617
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3618 if (len < 34)
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3619 {
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3620 vim_memset(buf + len, ' ', 34 - len);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3621 buf[34] = NUL;
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3622 }
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3623 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
3624 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3625 trunc_string(buf, buf, Columns - 1, IOSIZE);
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3626 msg(buf);
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3627 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3628
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3629 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3630 * ":colder [count]": Up in the quickfix stack.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3631 * ":cnewer [count]": Down in the quickfix stack.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3632 * ":lolder [count]": Up in the location list stack.
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3633 * ":lnewer [count]": Down in the location list stack.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3634 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3635 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3636 qf_age(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3637 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3638 qf_info_T *qi = &ql_info;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3639 int count;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3640
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3641 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3642 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3643 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3644 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3645 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3646 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3647 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3648 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3649 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3650
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3651 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3652 count = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3653 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3654 count = 1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3655 while (count--)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3656 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3657 if (eap->cmdidx == CMD_colder || eap->cmdidx == CMD_lolder)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3658 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3659 if (qi->qf_curlist == 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3660 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3661 EMSG(_("E380: At bottom of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3662 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3663 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3664 --qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3665 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3666 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3667 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3668 if (qi->qf_curlist >= qi->qf_listcount - 1)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3669 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3670 EMSG(_("E381: At top of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3671 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3672 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3673 ++qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3674 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3675 }
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3676 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
3677 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3678 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3679
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3680 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3681 * 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
3682 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3683 void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3684 qf_history(exarg_T *eap)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3685 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3686 qf_info_T *qi = &ql_info;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3687 int i;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3688
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3689 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
3690 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
3691 if (qf_stack_empty(qi))
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3692 MSG(_("No entries"));
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3693 else
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3694 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
3695 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
3696 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3697
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 * 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
3700 * associated with the list like context and title are not freed.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3701 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3702 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
3703 qf_free_items(qf_list_T *qfl)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3704 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3705 qfline_T *qfp;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3706 qfline_T *qfpnext;
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3707 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
3708
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 while (qfl->qf_count && qfl->qf_start != NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3710 {
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
3711 qfp = qfl->qf_start;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3712 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
3713 if (!stop)
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3714 {
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
3715 vim_free(qfp->qf_module);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3716 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
3717 vim_free(qfp->qf_pattern);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3718 stop = (qfp == qfpnext);
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3719 vim_free(qfp);
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3720 if (stop)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3721 // 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
3722 // 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
3723 // 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
3724 qfl->qf_count = 1;
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3725 }
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
3726 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
3727 --qfl->qf_count;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3728 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3729
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
3730 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
3731 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
3732 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
3733 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
3734 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
3735
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
3736 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
3737 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
3738 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
3739 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
3740 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
3741 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
3742 qfl->qf_multiscan = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3743 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3744
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3745 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3746 * 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
3747 * 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
3748 */
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3749 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
3750 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
3751 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3752 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
3753
13244
ac42c4b11dbc patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents: 13115
diff changeset
3754 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
3755 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
3756 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
3757 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
3758 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
3759 }
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3760
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3761 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3762 * qf_mark_adjust: adjust marks
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3763 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3764 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3765 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
3766 win_T *wp,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3767 linenr_T line1,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3768 linenr_T line2,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3769 long amount,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3770 long amount_after)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3771 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3772 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3773 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3774 int idx;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3775 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
3776 int found_one = FALSE;
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3777 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
3778
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3779 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
3780 return;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3781 if (wp != NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3782 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3783 if (wp->w_llist == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3784 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3785 qi = wp->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3786 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3787
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3788 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
3789 if (!qf_list_empty(qi, idx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3790 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
3791 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
3792 ++i, qfp = qfp->qf_next)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3793 if (qfp->qf_fnum == curbuf->b_fnum)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3794 {
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3795 found_one = TRUE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3796 if (qfp->qf_lnum >= line1 && qfp->qf_lnum <= line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3797 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3798 if (amount == MAXLNUM)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3799 qfp->qf_cleared = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3800 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3801 qfp->qf_lnum += amount;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3802 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3803 else if (amount_after && qfp->qf_lnum > line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3804 qfp->qf_lnum += amount_after;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3805 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3806
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3807 if (!found_one)
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3808 curbuf->b_has_qf_entry &= ~buf_has_flag;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3809 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3810
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3811 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3812 * Make a nice message out of the error character and the error number:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3813 * char number message
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3814 * e or E 0 " error"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3815 * w or W 0 " warning"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3816 * i or I 0 " info"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3817 * 0 0 ""
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3818 * other 0 " c"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3819 * e or E n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3820 * w or W n " warning n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3821 * i or I n " info n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3822 * 0 n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3823 * other n " c n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3824 * 1 x "" :helpgrep
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3825 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3826 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3827 qf_types(int c, int nr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3828 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3829 static char_u buf[20];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3830 static char_u cc[3];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3831 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3832
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3833 if (c == 'W' || c == 'w')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3834 p = (char_u *)" warning";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3835 else if (c == 'I' || c == 'i')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3836 p = (char_u *)" info";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3837 else if (c == 'E' || c == 'e' || (c == 0 && nr > 0))
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3838 p = (char_u *)" error";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3839 else if (c == 0 || c == 1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3840 p = (char_u *)"";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3841 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3842 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3843 cc[0] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3844 cc[1] = c;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3845 cc[2] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3846 p = cc;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3847 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3848
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3849 if (nr <= 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3850 return p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3851
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3852 sprintf((char *)buf, "%s %3d", (char *)p, nr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3853 return buf;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3854 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3855
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3856 /*
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
3857 * 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
3858 * 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
3859 */
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
3860 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
3861 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
3862 {
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
3863 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
3864
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
3865 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
3866 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
3867
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
3868 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
3869 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
3870
14491
9df0fcbfebb2 patch 8.1.0259: no test for fixed quickfix issue
Christian Brabandt <cb@256bit.org>
parents: 14477
diff changeset
3871 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
3872 {
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
3873 EMSG(_(e_quickfix));
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
3874 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
3875 }
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
3876
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
3877 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
3878 {
15024
3a3c9b638187 patch 8.1.0523: opening window from quickfix leaves empty buffer behind
Bram Moolenaar <Bram@vim.org>
parents: 14976
diff changeset
3879 // 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
3880 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
3881 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
3882 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
3883 }
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
3884
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
3885 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
3886 }
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
3887
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
3888 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3889 * ":cwindow": open the quickfix window if we have errors to display,
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3890 * close it if not.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3891 * ":lwindow": open the location list window if we have locations to display,
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3892 * close it if not.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3893 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3894 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3895 ex_cwindow(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3896 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3897 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
3898 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3899 win_T *win;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3900
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3901 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3902 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3903 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3904 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3905 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3906 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3907
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
3908 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
3909
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3910 // Look for an existing quickfix window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3911 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3912
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3913 // 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
3914 // 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
3915 // 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
3916 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
3917 || 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
3918 || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3919 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3920 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3921 ex_cclose(eap);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3922 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3923 else if (win == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3924 ex_copen(eap);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3925 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3926
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3927 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3928 * ":cclose": close the window showing the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3929 * ":lclose": close the window showing the location list
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3930 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3931 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3932 ex_cclose(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3933 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3934 win_T *win = NULL;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3935 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3936
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3937 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3938 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3939 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3940 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3941 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3942 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3943
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3944 // Find existing quickfix window and close it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3945 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3946 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3947 win_close(win, FALSE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3948 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3949
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3950 /*
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
3951 * 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
3952 */
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3953 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
3954 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
3955 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3956 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
3957 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
3958 }
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3959
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3960 /*
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3961 * 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
3962 * 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
3963 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3964 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3965 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
3966 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3967 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3968
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3969 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
3970 if (win == NULL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3971 return FAIL;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3972
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3973 win_goto(win);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3974 if (resize)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3975 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3976 if (vertsplit)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3977 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3978 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
3979 win_setwidth(sz);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3980 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3981 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
3982 win_setheight(sz);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3983 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3984
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3985 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3986 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3987
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 * 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
3990 * 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
3991 * 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
3992 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3993 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3994 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
3995 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3996 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
3997 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
3998 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
3999 int flags = 0;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4000 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4001
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4002 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
4003
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4004 // 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
4005 win = curwin;
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 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
4008 // 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
4009 // :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
4010 win_goto(lastwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4011 // 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
4012 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
4013 flags = WSP_BELOW;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4014 flags |= WSP_NEWLOC;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4015 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
4016 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
4017 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4018
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4019 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
4020 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4021 // 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
4022 // 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
4023 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
4024 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
4025 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4026
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4027 if (oldwin != curwin)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4028 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
4029 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
4030 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4031 // 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
4032 (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
4033 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
4034 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4035 else
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4036 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4037 // 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
4038 (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
4039
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4040 // switch off 'swapfile'
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4041 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
4042 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
4043 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4044 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
4045 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4046 #ifdef FEAT_DIFF
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4047 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
4048 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4049 #ifdef FEAT_FOLDING
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4050 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
4051 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4052 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4053 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4054
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4055 // 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
4056 // 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
4057 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
4058 win_setheight(height);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4059 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
4060 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
4061 prevwin = win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4062
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4063 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4064 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4065
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4066 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4067 * ":copen": open a window that shows the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4068 * ":lopen": open a window that shows the location list.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4069 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4070 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4071 ex_copen(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4072 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4073 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
4074 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4075 int height;
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4076 int status = FAIL;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4077 int lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4078
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4079 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4080 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4081 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4082 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4083 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4084 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4085 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4086 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4087 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4088
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4089 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4090
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4091 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4092 height = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4093 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4094 height = QF_WINHEIGHT;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4095
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4096 reset_VIsual_and_resel(); // stop Visual mode
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4097 #ifdef FEAT_GUI
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4098 need_mouse_correct = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4099 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4100
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4101 // 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
4102 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
4103 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
4104 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
4105 if (status == FAIL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4106 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
4107 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4108 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
4109 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4110 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4111
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4112 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
4113 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
4114 // 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
4115 // the quickfix list
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4116 lnum = qfl->qf_index;
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4117
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4118 // 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
4119 qf_fill_buffer(qi, curbuf, NULL);
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4120
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4121 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4122
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4123 curwin->w_cursor.lnum = lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4124 curwin->w_cursor.col = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4125 check_cursor();
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4126 update_topline(); // scroll to show the line
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4127 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4128
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4129 /*
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4130 * 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
4131 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4132 static void
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4133 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
4134 {
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4135 win_T *old_curwin = curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4136
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4137 curwin = win;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4138 curbuf = win->w_buffer;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4139 curwin->w_cursor.lnum = lnum;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4140 curwin->w_cursor.col = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4141 #ifdef FEAT_VIRTUALEDIT
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4142 curwin->w_cursor.coladd = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4143 #endif
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4144 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
4145 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
4146 redraw_later(VALID);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4147 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
4148 curwin = old_curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4149 curbuf = curwin->w_buffer;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4150 }
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4151
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4152 /*
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4153 * :cbottom/:lbottom commands.
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4154 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4155 void
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4156 ex_cbottom(exarg_T *eap)
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4157 {
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4158 qf_info_T *qi = &ql_info;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4159 win_T *win;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4160
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4161 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
4162 {
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4163 qi = GET_LOC_LIST(curwin);
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4164 if (qi == NULL)
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4165 {
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4166 EMSG(_(e_loclist));
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4167 return;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4168 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4169 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4170
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4171 win = qf_find_win(qi);
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4172 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
4173 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
4174 }
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4175
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4176 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4177 * Return the number of the current entry (line number in the quickfix
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4178 * window).
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4179 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4180 linenr_T
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4181 qf_current_entry(win_T *wp)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4182 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4183 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4184
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4185 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
4186 // In the location list window, use the referenced location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4187 qi = wp->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4188
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4189 return qi->qf_lists[qi->qf_curlist].qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4190 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4191
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4192 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4193 * Update the cursor position in the quickfix window to the current error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4194 * Return TRUE if there is a quickfix window.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4195 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4196 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4197 qf_win_pos_update(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4198 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
4199 int old_qf_index) // previous qf_index or zero
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4200 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4201 win_T *win;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4202 int qf_index = qi->qf_lists[qi->qf_curlist].qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4203
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4204 // 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
4205 // it's viewable.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4206 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4207 if (win != NULL
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4208 && qf_index <= win->w_buffer->b_ml.ml_line_count
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4209 && old_qf_index != qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4210 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4211 if (qf_index > old_qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4212 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4213 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
4214 win->w_redraw_bot = qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4215 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4216 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4217 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4218 win->w_redraw_top = qf_index;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4219 win->w_redraw_bot = old_qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4220 }
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4221 qf_win_goto(win, qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4222 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4223 return win != NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4224 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4225
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4226 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4227 * 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
4228 * stack.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4229 */
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4230 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4231 is_qf_win(win_T *win, qf_info_T *qi)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4232 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4233 // 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
4234 // set to NULL.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4235 // 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
4236 // pointing to the location list.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4237 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
4238 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
4239 || (IS_LL_STACK(qi) && win->w_llist_ref == qi))
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4240 return TRUE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4241
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4242 return FALSE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4243 }
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4244
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4245 /*
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
4246 * 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
4247 * Only searches in the current tabpage.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4248 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4249 static win_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4250 qf_find_win(qf_info_T *qi)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4251 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4252 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4253
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4254 FOR_ALL_WINDOWS(win)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4255 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
4256 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
4257 return NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4258 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4259
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4260 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4261 * Find a quickfix buffer.
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4262 * Searches in windows opened in all the tabs.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4263 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4264 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4265 qf_find_buf(qf_info_T *qi)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4266 {
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4267 tabpage_T *tp;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4268 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4269
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4270 FOR_ALL_TAB_WINDOWS(tp, win)
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4271 if (is_qf_win(win, qi))
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4272 return win->w_buffer;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4273
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4274 return NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4275 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4276
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4277 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4278 * 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
4279 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4280 static void
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4281 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
4282 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4283 win_T *win;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4284 win_T *curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4285
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4286 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
4287 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4288 curwin_save = curwin;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4289 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
4290 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
4291 curwin = curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4292 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4293 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4294
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4295 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4296 * Find the quickfix buffer. If it exists, update the contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4297 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4298 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4299 qf_update_buffer(qf_info_T *qi, qfline_T *old_last)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4300 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4301 buf_T *buf;
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4302 win_T *win;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4303 aco_save_T aco;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4304
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4305 // Check if a buffer for the quickfix list exists. Update it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4306 buf = qf_find_buf(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4307 if (buf != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4308 {
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4309 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
4310
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4311 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
4312 // 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
4313 aucmd_prepbuf(&aco, buf);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4314
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4315 qf_update_win_titlevar(qi);
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4316
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4317 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
4318 ++CHANGEDTICK(buf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4319
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4320 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4321 {
8932
25c2031e9f9f commit https://github.com/vim/vim/commit/c1808d5822ed9534ef7f0fe509b15bee92a5cc28
Christian Brabandt <cb@256bit.org>
parents: 8751
diff changeset
4322 (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
4323
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4324 // 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
4325 aucmd_restbuf(&aco);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4326 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4327
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4328 // 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
4329 // 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
4330 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
4331 redraw_buf_later(buf, NOT_VALID);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4332 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4333 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4334
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4335 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4336 * 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
4337 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4338 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4339 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
4340 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4341 int len;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4342 buf_T *errbuf;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4343
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4344 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
4345 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4346 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
4347 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4348 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4349 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
4350 && (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
4351 && errbuf->b_fname != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4352 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4353 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
4354 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
4355 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4356 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4357 // 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
4358 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
4359 || 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
4360 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4361 if (*dirname == NUL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4362 mch_dirname(dirname, MAXPATHL);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4363 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
4364 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4365 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
4366 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4367 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4368 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4369 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4370 len = 0;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4371 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4372
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4373 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
4374 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4375 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
4376 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
4377
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4378 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
4379 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4380 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
4381 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
4382 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4383
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4384 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
4385 (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
4386 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
4387 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4388 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
4389 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4390 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
4391 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
4392 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4393 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4394 IObuff[len++] = ' ';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4395
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4396 // 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
4397 // 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
4398 // 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
4399 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
4400 IObuff + len, IOSIZE - len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4401
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4402 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
4403 (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
4404 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4405
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4406 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4407 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4408
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4409 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4410 * Fill current buffer with quickfix errors, replacing any previous contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4411 * 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
4412 * 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
4413 * 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
4414 * ml_delete() is used and autocommands will be triggered.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4415 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4416 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4417 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
4418 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4419 linenr_T lnum;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4420 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4421 int old_KeyTyped = KeyTyped;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4422
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4423 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4424 {
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4425 if (buf != curbuf)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4426 {
10359
66f1b5bf3fa6 commit https://github.com/vim/vim/commit/95f096030ed1a8afea028f2ea295d6f6a70f466f
Christian Brabandt <cb@256bit.org>
parents: 10349
diff changeset
4427 internal_error("qf_fill_buffer()");
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4428 return;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4429 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4430
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4431 // delete all existing lines
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4432 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
4433 (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
4434 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4435
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4436 // 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
4437 if (!qf_stack_empty(qi))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4438 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4439 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
4440 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
4441
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4442 *dirname = NUL;
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4443
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4444 // 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
4445 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4446 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4447 qfp = qfl->qf_start;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4448 lnum = 0;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4449 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4450 else
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4451 {
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4452 qfp = old_last->qf_next;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4453 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
4454 }
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4455 while (lnum < qfl->qf_count)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4456 {
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4457 if (qf_buf_add_line(buf, lnum, qfp, dirname) == FAIL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4458 break;
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4459
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4460 ++lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4461 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4462 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4463 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4464 }
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4465
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4466 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
4467 // 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
4468 (void)ml_delete(lnum + 1, FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4469 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4470
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4471 // correct cursor position
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4472 check_lnums(TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4473
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4474 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4475 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4476 // 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
4477 // 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
4478 // using autocommands.
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4479 ++curbuf_lock;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4480 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
4481 curbuf->b_p_ma = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4482
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4483 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
4484 apply_autocmds(EVENT_BUFREADPOST, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4485 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4486 apply_autocmds(EVENT_BUFWINENTER, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4487 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4488 keep_filetype = FALSE;
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4489 --curbuf_lock;
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
4490
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4491 // 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
4492 redraw_curbuf_later(NOT_VALID);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4493 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4494
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4495 // Restore KeyTyped, setting 'filetype' may reset it.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4496 KeyTyped = old_KeyTyped;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4497 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4498
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4499 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4500 * 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
4501 */
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4502 static void
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4503 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
4504 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4505 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
4506 }
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4507
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4508 /*
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4509 * 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
4510 * 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
4511 */
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4512 static int
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4513 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
4514 {
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4515 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
4516
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4517 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
4518 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
4519 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
4520 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
4521 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4522
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4523 /*
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4524 * 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
4525 * 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
4526 * 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
4527 * 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
4528 * 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
4529 */
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4530 static int
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4531 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
4532 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4533 int curlist;
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4534
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4535 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
4536 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4537 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
4538 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
4539 // 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
4540 return FAIL;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4541 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
4542 }
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4543 return OK;
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4544 }
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4545
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4546 /*
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4547 * 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
4548 */
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4549 static void
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4550 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
4551 {
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4552 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
4553 return;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4554
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4555 // 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
4556 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
4557 qf_jump(qi, 0, 0, forceit);
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4558 }
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4559
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4560 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4561 * Return TRUE when using ":vimgrep" for ":grep".
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4562 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4563 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4564 grep_internal(cmdidx_T cmdidx)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4565 {
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4566 return ((cmdidx == CMD_grep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4567 || cmdidx == CMD_lgrep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4568 || cmdidx == CMD_grepadd
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4569 || cmdidx == CMD_lgrepadd)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4570 && STRCMP("internal",
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4571 *curbuf->b_p_gp == NUL ? p_gp : curbuf->b_p_gp) == 0);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4572 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4573
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4574 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4575 * 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
4576 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4577 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4578 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
4579 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4580 switch (cmdidx)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4581 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4582 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
4583 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
4584 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
4585 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
4586 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
4587 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
4588 default: return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4589 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4590 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4591
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4592 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4593 * Return the name for the errorfile, in allocated memory.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4594 * Find a new unique name when 'makeef' contains "##".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4595 * Returns NULL for error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4596 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4597 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4598 get_mef_name(void)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4599 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4600 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4601 char_u *name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4602 static int start = -1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4603 static int off = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4604 #ifdef HAVE_LSTAT
9387
f094d4085014 commit https://github.com/vim/vim/commit/8767f52fbfd4f053ce00a978227c95f1d7d323fe
Christian Brabandt <cb@256bit.org>
parents: 9379
diff changeset
4605 stat_T sb;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4606 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4607
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4608 if (*p_mef == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4609 {
6721
7347229a646a updated for version 7.4.684
Bram Moolenaar <bram@vim.org>
parents: 6450
diff changeset
4610 name = vim_tempname('e', FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4611 if (name == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4612 EMSG(_(e_notmp));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4613 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4614 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4615
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4616 for (p = p_mef; *p; ++p)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4617 if (p[0] == '#' && p[1] == '#')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4618 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4619
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4620 if (*p == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4621 return vim_strsave(p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4622
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4623 // Keep trying until the name doesn't exist yet.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4624 for (;;)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4625 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4626 if (start == -1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4627 start = mch_get_pid();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4628 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4629 off += 19;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4630
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4631 name = alloc((unsigned)STRLEN(p_mef) + 30);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4632 if (name == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4633 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4634 STRCPY(name, p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4635 sprintf((char *)name + (p - p_mef), "%d%d", start, off);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4636 STRCAT(name, p + 2);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4637 if (mch_getperm(name) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4638 #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
4639 // Don't accept a symbolic link, it's a security risk.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4640 && mch_lstat((char *)name, &sb) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4641 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4642 )
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4643 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4644 vim_free(name);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4645 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4646 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4647 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4648
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4649 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4650 * 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
4651 * 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
4652 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4653 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4654 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
4655 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4656 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4657 unsigned len;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4658
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4659 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
4660 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
4661 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
4662 cmd = alloc(len);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4663 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4664 return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4665 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
4666 (char *)p_shq);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4667
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4668 // 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
4669 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
4670 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
4671
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4672 // 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
4673 // 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
4674 // in column 0).
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4675 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
4676 msg_didout = FALSE;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4677 msg_start();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4678 MSG_PUTS(":!");
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4679 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
4680
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4681 return cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4682 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4683
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 * 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
4686 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4687 void
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4688 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
4689 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4690 char_u *fname;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4691 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4692 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
4693 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
4694 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
4695 int res;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4696 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
4697 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
4698
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4699 // 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
4700 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
4701 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4702 ex_vimgrep(eap);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4703 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4704 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4705
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4706 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
4707 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
4708 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
4709 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4710 #ifdef FEAT_EVAL
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4711 if (aborting())
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4712 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4713 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4714 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4715 #ifdef FEAT_MBYTE
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4716 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
4717 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4718
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4719 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
4720 wp = curwin;
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 autowrite_all();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4723 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
4724 if (fname == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4725 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4726 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
4727
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4728 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
4729 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4730 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4731
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4732 // 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
4733 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
4734
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4735 #ifdef AMIGA
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4736 out_flush();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4737 // 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
4738 (void)char_avail();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4739 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4740
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4741 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4742
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4743 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
4744 && 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
4745 (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
4746 && 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
4747 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
4748 if (wp != NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4749 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4750 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
4751 if (qi == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4752 goto cleanup;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4753 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4754 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4755 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
4756
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4757 // 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
4758 // 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
4759 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
4760 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
4761 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
4762 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
4763 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
4764 // 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
4765 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
4766
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4767 cleanup:
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4768 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
4769 mch_remove(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4770 vim_free(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4771 vim_free(cmd);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4772 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4773
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4774 /*
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4775 * 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
4776 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4777 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4778 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
4779 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4780 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
4781 qf_list_T *qfl;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4782 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4783 int i, sz = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4784 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4785
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4786 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
4787 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4788 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4789 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4790 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4791 return 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4792 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4793
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4794 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
4795 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
4796 ++i, qfp = qfp->qf_next)
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 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4799 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4800 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
4801 sz++; // Count all valid entries
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4802 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
4803 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4804 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4805 sz++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4806 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4807 }
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 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4810
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4811 return sz;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4812 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4813
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4814 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4815 * 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
4816 * 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
4817 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4818 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4819 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
4820 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4821 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4822
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4823 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
4824 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4825 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4826 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4827 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4828 return 0;
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
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4831 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
4832 }
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 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4835 * 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
4836 * 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
4837 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4838 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4839 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
4840 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4841 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4842 qf_list_T *qfl;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4843 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4844 int i, eidx = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4845 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4846
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4847 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
4848 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4849 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4850 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4851 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4852 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4853 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4854
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4855 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
4856 qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4857
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4858 // 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
4859 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
4860 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4861
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4862 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
4863 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4864 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4865 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4866 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
4867 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4868 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
4869 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4870 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4871 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4872 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4873 }
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 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4876 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4877 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4878 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4879
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4880 return eidx ? eidx : 1;
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
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4883 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4884 * 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
4885 * 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
4886 * 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
4887 * 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
4888 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4889 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
4890 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
4891 {
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4892 qfline_T *qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4893 int i, eidx;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4894 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4895
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4896 // 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
4897 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
4898 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4899
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4900 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
4901 i++, qfp = qfp->qf_next)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4902 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4903 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4904 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4905 if (fdo)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4906 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4907 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
4908 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4909 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4910 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4911 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4912 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4913 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4914 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4915 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4916 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4917
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4918 if (eidx == n)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4919 break;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4920 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4921
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4922 if (i <= qfl->qf_count)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4923 return i;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4924 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4925 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4926 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4927
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4928 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4929 * ":cc", ":crewind", ":cfirst" and ":clast".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4930 * ":ll", ":lrewind", ":lfirst" and ":llast".
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4931 * ":cdo", ":ldo", ":cfdo" and ":lfdo"
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4932 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4933 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4934 ex_cc(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4935 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4936 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
4937 int errornr;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4938
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4939 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4940 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4941 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4942 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4943 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4944 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4945 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4946 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4947 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4948
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4949 if (eap->addr_count > 0)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4950 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4951 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4952 {
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4953 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4954 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4955 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
4956 errornr = 0;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4957 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4958 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
4959 case CMD_lfirst:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4960 errornr = 1;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4961 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4962 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4963 errornr = 32767;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4964 }
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4965 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4966
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4967 // 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
4968 // 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
4969 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
4970 || 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
4971 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
4972 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
4973 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
4974
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4975 qf_jump(qi, 0, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4976 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4977
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4978 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4979 * ":cnext", ":cnfile", ":cNext" and ":cprevious".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4980 * ":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
4981 * Also, used by ":cdo", ":ldo", ":cfdo" and ":lfdo" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4982 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4983 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4984 ex_cnext(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4985 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4986 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
4987 int errornr;
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4988 int dir;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4989
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4990 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4991 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4992 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4993 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4994 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4995 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4996 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4997 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4998 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4999
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
5000 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
5001 && (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
5002 && 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
5003 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
5004 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
5005 errornr = 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
5006
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5007 // 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
5008 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5009 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5010 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
5011 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5012 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5013 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
5014 case CMD_lNext:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5015 dir = BACKWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5016 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5017 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
5018 dir = FORWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5019 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5020 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
5021 dir = BACKWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5022 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5023 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5024 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5025 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5026 }
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5027
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5028 qf_jump(qi, dir, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5029 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5030
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5031 /*
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
5032 * ":cfile"/":cgetfile"/":caddfile" commands.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
5033 * ":lfile"/":lgetfile"/":laddfile" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5034 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5035 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5036 ex_cfile(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5037 {
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
5038 char_u *enc = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
5039 win_T *wp = NULL;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
5040 qf_info_T *qi = &ql_info;
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5041 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
5042 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
5043 int res;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
5044
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5045 switch (eap->cmdidx)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5046 {
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5047 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
5048 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
5049 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
5050 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
5051 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
5052 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
5053 default: break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5054 }
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5055 if (au_name != NULL)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5056 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
5057 #ifdef FEAT_MBYTE
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
5058 enc = (*curbuf->b_p_menc != NUL) ? curbuf->b_p_menc : p_menc;
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
5059 #endif
2296
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5060 #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
5061 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
5062 {
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5063 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
5064 NULL, NULL,
378f9f8e6d8f patch 8.0.1773: dialog messages are not translated
Christian Brabandt <cb@256bit.org>
parents: 13800
diff changeset
5065 (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
5066 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
5067 return;
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5068 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
5069 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
5070 }
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5071 else
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5072 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5073 if (*eap->arg != NUL)
694
07d199fe02ed updated for version 7.0209
vimboss
parents: 682
diff changeset
5074 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
5075
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5076 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
5077 wp = curwin;
a1f8939a4644 patch 8.0.1414: accessing freed memory in :lfile.
Christian Brabandt <cb@256bit.org>
parents: 13076
diff changeset
5078
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5079 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5080
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5081 // 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
5082 // commands.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5083 // :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
5084 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5085 // :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
5086 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5087 // :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
5088 // 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
5089 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
5090 && 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
5091 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
5092 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
5093 {
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5094 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
5095 if (qi == NULL)
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5096 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5097 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
5098 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5099 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5100 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5101 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5102 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
5103 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
5104 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
5105 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
5106
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5107 // 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
5108 // 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
5109 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
5110 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5111 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5112 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
5113
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5114 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
5115 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5116
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5117 /*
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5118 * 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
5119 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5120 static char_u *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5121 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
5122 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5123 switch (cmdidx)
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 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
5126 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
5127 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
5128 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
5129 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
5130 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
5131 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
5132 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
5133 default: return NULL;
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 }
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 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5138 * 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
5139 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5140 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5141 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
5142 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5143 // 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
5144 regmatch->regprog = NULL;
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 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
5147 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5148 // 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
5149 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
5150 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5151 EMSG(_(e_noprevre));
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5152 return;
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 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
5155 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5156 else
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5157 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
5158
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5159 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
5160 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
5161 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5162
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5163 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5164 * 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
5165 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5166 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5167 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
5168 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5169 char_u *p;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5170
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5171 msg_start();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5172 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
5173 if (p == NULL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5174 msg_outtrans(fname);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5175 else
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5176 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5177 msg_outtrans(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5178 vim_free(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5179 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5180 msg_clr_eos();
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5181 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
5182 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
5183 msg_col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5184 out_flush();
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
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 * 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
5189 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5190 static buf_T *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5191 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
5192 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5193 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
5194 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
5195 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5196 int save_mls;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5197 #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
5198 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
5199 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5200 buf_T *buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5201
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5202 #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
5203 // 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
5204 // 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
5205 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
5206 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5207 // 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
5208 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
5209 p_mls = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5210
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5211 // 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
5212 // 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
5213 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
5214
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5215 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
5216 #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
5217 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
5218 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5219
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5220 return buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5221 }
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 * 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
5225 * 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
5226 * new 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_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
5230 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
5231 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
5232 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
5233 char_u *title)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5234 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5235 // 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
5236 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
5237 {
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5238 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
5239 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5240 // An autocmd has freed the location list.
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5241 EMSG(_(e_loc_list_changed));
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5242 return FALSE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5243 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5244 else
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5245 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5246 // 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
5247 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
5248 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
5249 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5250 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5251
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
5252 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
5253 return FALSE;
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5254
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5255 return TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5256 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5257
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5258 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5259 * 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
5260 * 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
5261 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5262 static int
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5263 vgr_match_buflines(
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5264 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
5265 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5266 buf_T *buf,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5267 regmmatch_T *regmatch,
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5268 long *tomatch,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5269 int duplicate_name,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5270 int flags)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5271 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5272 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
5273 long lnum;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5274 colnr_T col;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5275
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5276 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
5277 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5278 col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5279 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
5280 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
5281 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5282 // 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
5283 // 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
5284 // 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
5285 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
5286 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5287 NULL, // dir
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5288 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
5289 NULL,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5290 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
5291 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
5292 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
5293 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
5294 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
5295 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5296 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5297 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5298 0, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5299 TRUE // valid
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5300 ) == FAIL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5301 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5302 got_int = TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5303 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5304 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5305 found_match = TRUE;
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5306 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
5307 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5308 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
5309 || 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
5310 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5311 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
5312 + (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
5313 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
5314 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5315 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5316 line_breakcheck();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5317 if (got_int)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5318 break;
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 return found_match;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5322 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5323
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5324 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5325 * 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
5326 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5327 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5328 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
5329 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
5330 int forceit,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5331 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
5332 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
5333 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
5334 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5335 buf_T *buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5336
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5337 buf = curbuf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5338 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
5339 if (buf != curbuf)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5340 // 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
5341 // 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
5342 *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
5343
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5344 // 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
5345 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
5346 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5347 exarg_T ea;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5348
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5349 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
5350 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
5351 ex_cd(&ea);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5352 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5353 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5354
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5355 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5356 * ":vimgrep {pattern} file(s)"
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5357 * ":vimgrepadd {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5358 * ":lvimgrep {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5359 * ":lvimgrepadd {pattern} file(s)"
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5360 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5361 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5362 ex_vimgrep(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5363 {
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5364 regmmatch_T regmatch;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5365 int fcount;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5366 char_u **fnames;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5367 char_u *fname;
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5368 char_u *title;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5369 char_u *s;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5370 char_u *p;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5371 int fi;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5372 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
5373 qf_list_T *qfl;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5374 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
5375 win_T *wp = NULL;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5376 buf_T *buf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5377 int duplicate_name = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5378 int using_dummy;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5379 int redraw_for_dummy = FALSE;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5380 int found_match;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5381 buf_T *first_match_buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5382 time_t seconds = 0;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5383 aco_save_T aco;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5384 int flags = 0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5385 long tomatch;
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5386 char_u *dirname_start = NULL;
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5387 char_u *dirname_now = NULL;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5388 char_u *target_dir = NULL;
1683
75dbeedddaa9 updated for version 7.2b-016
vimboss
parents: 1672
diff changeset
5389 char_u *au_name = NULL;
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5390
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5391 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
5392 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
5393 curbuf->b_fname, TRUE, curbuf))
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5394 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5395 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
5396 if (aborting())
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5397 return;
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5398 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5399 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5400
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5401 if (is_loclist_cmd(eap->cmdidx))
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5402 {
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5403 qi = ll_get_or_alloc_list(curwin);
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5404 if (qi == NULL)
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5405 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
5406 wp = curwin;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5407 }
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5408
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5409 if (eap->addr_count > 0)
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5410 tomatch = eap->line2;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5411 else
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5412 tomatch = MAXLNUM;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5413
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5414 // Get the search pattern: either white-separated or enclosed in //
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5415 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
5416 title = vim_strsave(qf_cmdtitle(*eap->cmdlinep));
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5417 p = skip_vimgrep_pat(eap->arg, &s, &flags);
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5418 if (p == NULL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5419 {
282
33d9c918b8ab updated for version 7.0075
vimboss
parents: 277
diff changeset
5420 EMSG(_(e_invalpat));
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5421 goto theend;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5422 }
4197
07fef68eb018 updated for version 7.3.850
Bram Moolenaar <bram@vim.org>
parents: 4003
diff changeset
5423
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5424 vgr_init_regmatch(&regmatch, s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5425 if (regmatch.regprog == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5426 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5427
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5428 p = skipwhite(p);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5429 if (*p == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5430 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5431 EMSG(_("E683: File name missing or invalid pattern"));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5432 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5433 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5434
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
5435 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
5436 && 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
5437 && 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
5438 || 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
5439 // 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
5440 qf_new_list(qi, title != NULL ? title : qf_cmdtitle(*eap->cmdlinep));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5441
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5442 // parse the list of arguments
3620
4f1c511e71f8 updated for version 7.3.570
Bram Moolenaar <bram@vim.org>
parents: 3555
diff changeset
5443 if (get_arglist_exp(p, &fcount, &fnames, TRUE) == FAIL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5444 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5445 if (fcount == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5446 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5447 EMSG(_(e_nomatch));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5448 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5449 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5450
7558
9a4c9dccd603 commit https://github.com/vim/vim/commit/b86a343280b08d6701da68ee0651e960a0a7a61c
Christian Brabandt <cb@256bit.org>
parents: 7515
diff changeset
5451 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
5452 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
5453 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
5454 {
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5455 FreeWild(fcount, fnames);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5456 goto theend;
7662
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5457 }
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5458
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5459 // 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
5460 // ":lcd %:p:h" changes the meaning of short path names.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5461 mch_dirname(dirname_start, MAXPATHL);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5462
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5463 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5464
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5465 // 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
5466 // 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
5467 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
5468
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5469 seconds = (time_t)0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5470 for (fi = 0; fi < fcount && !got_int && tomatch > 0; ++fi)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5471 {
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5472 fname = shorten_fname1(fnames[fi]);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5473 if (time(NULL) > seconds)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5474 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5475 // 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
5476 // working on it.
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5477 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
5478 vgr_display_fname(fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5479 }
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5480
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5481 buf = buflist_findname_exp(fnames[fi]);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5482 if (buf == NULL || buf->b_ml.ml_mfp == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5483 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5484 // Remember that a buffer with this name already exists.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5485 duplicate_name = (buf != NULL);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5486 using_dummy = TRUE;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5487 redraw_for_dummy = TRUE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5488
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5489 buf = vgr_load_dummy_buf(fname, dirname_start, dirname_now);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5490 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5491 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5492 // Use existing, loaded buffer.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5493 using_dummy = FALSE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5494
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5495 // 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
5496 // 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
5497 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
5498 {
2d94fcb0277d patch 8.0.1702: leaking memory when autocommands make quickfix list invalid
Christian Brabandt <cb@256bit.org>
parents: 13612
diff changeset
5499 FreeWild(fcount, fnames);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5500 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
5501 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
5502 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5503 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
5504
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5505 if (buf == NULL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5506 {
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5507 if (!got_int)
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5508 smsg((char_u *)_("Cannot open file \"%s\""), fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5509 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5510 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5511 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5512 // 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
5513 // 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
5514 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
5515 &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
5516
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5517 if (using_dummy)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5518 {
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5519 if (found_match && first_match_buf == NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5520 first_match_buf = buf;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5521 if (duplicate_name)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5522 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5523 // 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
5524 // with the same name.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5525 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5526 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5527 }
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5528 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
5529 || 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
5530 || 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
5531 || buf->b_p_bh[0] == 'd') // "delete"
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5532 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5533 // 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
5534 // 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
5535 // 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
5536 // unload the buffer.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5537 // 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
5538 // many swap files.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5539 if (!found_match)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5540 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5541 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5542 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5543 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5544 else if (buf != first_match_buf || (flags & VGR_NOJUMP))
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5545 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5546 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
5547 // 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
5548 buf->b_flags &= ~BF_DUMMY;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5549 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5550 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5551 }
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5552
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5553 if (buf != NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5554 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5555 // 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
5556 buf->b_flags &= ~BF_DUMMY;
64a791c53418 commit https://github.com/vim/vim/commit/015102e91e978a0bb42a14461c132a85e8f7e1ea
Christian Brabandt <cb@256bit.org>
parents: 9538
diff changeset
5557
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5558 // 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
5559 // directory we jumped to below.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5560 if (buf == first_match_buf
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5561 && target_dir == NULL
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5562 && STRCMP(dirname_start, dirname_now) != 0)
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5563 target_dir = vim_strsave(dirname_now);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5564
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5565 // 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
5566 // 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
5567 // 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
5568 // options!
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5569 aucmd_prepbuf(&aco, buf);
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5570 #if defined(FEAT_SYN_HL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5571 apply_autocmds(EVENT_FILETYPE, buf->b_p_ft,
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5572 buf->b_fname, TRUE, buf);
677
e649c78407e6 updated for version 7.0202
vimboss
parents: 665
diff changeset
5573 #endif
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5574 do_modelines(OPT_NOWIN);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5575 aucmd_restbuf(&aco);
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5576 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5577 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5578 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5579 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5580
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5581 FreeWild(fcount, fnames);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5582
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5583 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
5584 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5585 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
5586 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5587 qf_list_changed(qfl);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5588
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
5589 qf_update_buffer(qi, NULL);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5590
842
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5591 if (au_name != NULL)
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5592 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5593 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
5594 // 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
5595 // is still valid.
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5596 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
5597 || 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
5598 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5599 decr_quickfix_busy();
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5600 goto theend;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5601 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5602
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
5603 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5604 if (!qf_list_empty(qi, qi->qf_curlist))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5605 {
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5606 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
5607 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
5608 first_match_buf, target_dir);
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5609 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5610 else
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5611 EMSG2(_(e_nomatch2), s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5612
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5613 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5614
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5615 // 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
5616 // may have messed up things, need to redraw and recompute folds.
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5617 if (redraw_for_dummy)
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5618 {
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5619 #ifdef FEAT_FOLDING
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5620 foldUpdateAll(curwin);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5621 #else
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5622 redraw_later(NOT_VALID);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5623 #endif
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5624 }
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5625
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5626 theend:
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5627 vim_free(title);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5628 vim_free(dirname_now);
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5629 vim_free(dirname_start);
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5630 vim_free(target_dir);
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
5631 vim_regfree(regmatch.regprog);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5632 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5633
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5634 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5635 * 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
5636 * 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
5637 */
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5638 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5639 restore_start_dir(char_u *dirname_start)
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5640 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5641 char_u *dirname_now = alloc(MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5642
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5643 if (NULL != dirname_now)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5644 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5645 mch_dirname(dirname_now, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5646 if (STRCMP(dirname_start, dirname_now) != 0)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5647 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5648 // 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
5649 // appropriate ex command and executing it.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5650 exarg_T ea;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5651
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5652 ea.arg = dirname_start;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5653 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
5654 ex_cd(&ea);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5655 }
3974
4d1753f3e85c updated for version 7.3.742
Bram Moolenaar <bram@vim.org>
parents: 3965
diff changeset
5656 vim_free(dirname_now);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5657 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5658 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5659
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5660 /*
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5661 * 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
5662 * 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
5663 * "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
5664 * 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
5665 * 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
5666 *
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5667 * 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
5668 * or wipe_dummy_buffer() later!
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5669 *
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5670 * Returns NULL if it fails.
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5671 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5672 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5673 load_dummy_buffer(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5674 char_u *fname,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5675 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
5676 char_u *resulting_dir) // out: new directory
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5677 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5678 buf_T *newbuf;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5679 bufref_T newbufref;
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5680 bufref_T newbuf_to_wipe;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5681 int failed = TRUE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5682 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
5683 int readfile_result;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5684
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5685 // Allocate a buffer without putting it in the buffer list.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5686 newbuf = buflist_new(NULL, NULL, (linenr_T)1, BLN_DUMMY);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5687 if (newbuf == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5688 return NULL;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5689 set_bufref(&newbufref, newbuf);
42
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 // Init the options.
177
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5692 buf_copy_options(newbuf, BCO_ENTER | BCO_NOHELP);
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5693
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5694 // 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
5695 if (ml_open(newbuf) == OK)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5696 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5697 // 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
5698 ++newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
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 // set curwin/curbuf to buf and save a few things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5701 aucmd_prepbuf(&aco, newbuf);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5702
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5703 // Need to set the filename for autocommands.
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5704 (void)setfname(curbuf, fname, NULL, FALSE);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5705
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5706 // Create swap file now to avoid the ATTENTION message.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5707 check_need_swap(TRUE);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5708
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5709 // 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
5710 // work.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5711 curbuf->b_flags &= ~BF_DUMMY;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5712
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5713 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
5714 readfile_result = readfile(fname, NULL,
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5715 (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
5716 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
5717 --newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5718 if (readfile_result == OK
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5719 && !got_int
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5720 && !(curbuf->b_flags & BF_NEW))
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5721 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5722 failed = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5723 if (curbuf != newbuf)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5724 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5725 // 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
5726 // 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
5727 // 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
5728 // window stuff.
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5729 set_bufref(&newbuf_to_wipe, newbuf);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5730 newbuf = curbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5731 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5732 }
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
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 // restore curwin/curbuf and a few other things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5735 aucmd_restbuf(&aco);
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5736 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
5737 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
5738
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5739 // 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
5740 // skip it.
9485
c16e207dc465 commit https://github.com/vim/vim/commit/ea3f2e7be447a8f0c4436869620f908de5e8ef1e
Christian Brabandt <cb@256bit.org>
parents: 9475
diff changeset
5741 newbuf->b_flags |= BF_DUMMY;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5742 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5743
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5744 // When autocommands/'autochdir' option changed directory: go back.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5745 // 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
5746 // important.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5747 mch_dirname(resulting_dir, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5748 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5749
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5750 if (!bufref_valid(&newbufref))
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5751 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5752 if (failed)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5753 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5754 wipe_dummy_buffer(newbuf, dirname_start);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5755 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5756 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5757 return newbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5758 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5759
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5760 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5761 * 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
5762 * 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
5763 * 'autochdir' option have changed it.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5764 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5765 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5766 wipe_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5767 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5768 if (curbuf != buf) // safety check
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5769 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5770 #if defined(FEAT_EVAL)
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5771 cleanup_T cs;
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5772
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5773 // 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
5774 // 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
5775 // work when got_int is set.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5776 enter_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5777 #endif
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5778
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5779 wipe_buffer(buf, FALSE);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5780
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5781 #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
5782 // 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
5783 // new aborting error, interrupt, or uncaught exception.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5784 leave_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5785 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5786 // 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
5787 restore_start_dir(dirname_start);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5788 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5789 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5790
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5791 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5792 * 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
5793 * 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
5794 * 'autochdir' option have changed it.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5795 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5796 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5797 unload_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5798 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5799 if (curbuf != buf) // safety check
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5800 {
3365
9ccdc4a69d8f updated for version 7.3.449
Bram Moolenaar <bram@vim.org>
parents: 3269
diff changeset
5801 close_buffer(NULL, buf, DOBUF_UNLOAD, FALSE);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5802
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5803 // 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
5804 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5805 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5806 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5807
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5808 #if defined(FEAT_EVAL) || defined(PROTO)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5809 /*
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5810 * 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
5811 * 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
5812 */
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5813 int
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5814 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
5815 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5816 qf_info_T *qi = qi_arg;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5817 dict_T *dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5818 char_u buf[2];
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5819 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5820 int i;
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5821 int bufnum;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5822
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5823 if (qi == NULL)
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5824 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5825 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
5826 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
5827 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5828 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
5829 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
5830 return FAIL;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5831 }
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5832 }
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5833
13800
e4dc4ede9ef8 patch 8.0.1772: quickfix: mixup of FALSE and FAIL, returning -1
Christian Brabandt <cb@256bit.org>
parents: 13764
diff changeset
5834 if (qf_idx == INVALID_QFIDX)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5835 qf_idx = qi->qf_curlist;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5836
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5837 if (qf_idx >= qi->qf_listcount || qf_list_empty(qi, qf_idx))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5838 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5839
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5840 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
5841 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
5842 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5843 // Handle entries with a non-existing buffer number.
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5844 bufnum = qfp->qf_fnum;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5845 if (bufnum != 0 && (buflist_findnr(bufnum) == NULL))
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5846 bufnum = 0;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5847
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5848 if ((dict = dict_alloc()) == NULL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5849 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5850 if (list_append_dict(list, dict) == FAIL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5851 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5852
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5853 buf[0] = qfp->qf_type;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5854 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
5855 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
5856 || 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
5857 || 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
5858 || 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
5859 || 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
5860 || 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
5861 || 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
5862 || 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
5863 || 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
5864 || dict_add_number(dict, "valid", (long)qfp->qf_valid) == FAIL)
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5865 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5866
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5867 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5868 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5869 break;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5870 }
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5871 return OK;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5872 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5873
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5874 // 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
5875 enum {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5876 QF_GETLIST_NONE = 0x0,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5877 QF_GETLIST_TITLE = 0x1,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5878 QF_GETLIST_ITEMS = 0x2,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5879 QF_GETLIST_NR = 0x4,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5880 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
5881 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
5882 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
5883 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
5884 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
5885 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
5886 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
5887 QF_GETLIST_ALL = 0x3FF,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5888 };
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5889
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5890 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5891 * 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
5892 * 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
5893 */
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5894 static int
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5895 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
5896 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5897 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
5898 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
5899 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
5900 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
5901 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
5902
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5903 // 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
5904 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
5905 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5906 // 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
5907 // option setting
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5908 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
5909 {
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5910 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
5911 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
5912 return FAIL;
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5913 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
5914 }
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5915
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5916 l = list_alloc();
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5917 if (l == NULL)
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5918 return FAIL;
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5919
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
5920 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
5921 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
5922 {
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5923 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
5924 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
5925 {
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5926 (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
5927 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
5928 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5929 free(qi);
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5930 }
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5931 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
5932 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
5933 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5934
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5935 return status;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5936 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5937
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5938 /*
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
5939 * 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
5940 */
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
5941 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
5942 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
5943 {
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
5944 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
5945
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5946 // 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
5947 // 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
5948 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
5949 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
5950 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
5951 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
5952 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
5953 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
5954 }
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
5955
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
5956 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5957 * Convert the keys in 'what' to quickfix list property flags.
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5958 */
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5959 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
5960 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
5961 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5962 int flags = QF_GETLIST_NONE;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5963
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5964 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
5965 {
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5966 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
5967 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
5968 // 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
5969 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
5970 }
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5971
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5972 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
5973 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
5974
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5975 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
5976 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
5977
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5978 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
5979 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
5980
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5981 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
5982 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
5983
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5984 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
5985 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
5986
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5987 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
5988 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
5989
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
5990 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
5991 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
5992
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5993 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
5994 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
5995
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5996 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
5997 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
5998
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
5999 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
6000 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
6001
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6002 return flags;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6003 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6004
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6005 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6006 * 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
6007 * 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
6008 * quickfix list index.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6009 * 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
6010 * 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
6011 * 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
6012 * 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
6013 * 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
6014 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6015 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6016 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
6017 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6018 int qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6019 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6020
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6021 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
6022 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
6023 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6024 // 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
6025 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
6026 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6027 // 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
6028 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
6029 {
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6030 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
6031 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
6032 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
6033 }
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
6034 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6035 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
6036 && 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
6037 && 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
6038 // 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
6039 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
6040 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6041 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
6042 }
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 ((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
6045 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6046 // 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
6047 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
6048 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6049 // 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
6050 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
6051 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
6052 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6053 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6054 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
6055 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6056
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6057 return qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6058 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6059
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 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
6062 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6063 static int
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6064 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
6065 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6066 int status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6067
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6068 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
6069 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
6070 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
6071 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6072 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
6073 if (l != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6074 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
6075 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6076 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6077 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6078 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
6079 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
6080 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
6081 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
6082 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
6083 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
6084 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
6085 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
6086 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
6087 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
6088 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
6089 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
6090 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
6091 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
6092 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
6093 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
6094
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6095 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6096 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6097
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6098 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6099 * 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
6100 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6101 static int
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6102 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
6103 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6104 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
6105 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6106
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6107 /*
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
6108 * 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
6109 * 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
6110 * 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
6111 */
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6112 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
6113 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
6114 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6115 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
6116
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6117 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
6118 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6119 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
6120 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
6121 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
6122 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6123
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6124 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
6125 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6126
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6127 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6128 * 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
6129 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6130 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6131 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
6132 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6133 int status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6134 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
6135 if (l != NULL)
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 (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
6138 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
6139 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6140 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6141 status = FAIL;
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 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6144 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6145
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6146 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6147 * 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
6148 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6149 static int
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6150 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
6151 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6152 int status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6153 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6154
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6155 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
6156 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6157 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
6158 if (di != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6159 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6160 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
6161 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
6162 if (status == FAIL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6163 dictitem_free(di);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6164 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6165 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6166 status = FAIL;
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 else
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6169 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
6170
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6171 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6172 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6173
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6174 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6175 * 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
6176 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6177 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6178 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
6179 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6180 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
6181 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
6182 // 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
6183 curidx = 0;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6184 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
6185 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6186
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6187 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6188 * 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
6189 * 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
6190 * 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
6191 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6192 int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6193 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
6194 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6195 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
6196 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
6197 int status = OK;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6198 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
6199 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6200 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
6201
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6202 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
6203 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
6204
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6205 if (wp != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6206 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
6207
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
6208 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
6209
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6210 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
6211 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
6212
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6213 // 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
6214 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
6215 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
6216
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
6217 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
6218
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6219 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
6220 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
6221 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
6222 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
6223 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
6224 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
6225 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
6226 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
6227 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
6228 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
6229 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
6230 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
6231 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
6232 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
6233 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
6234 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
6235 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
6236 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
6237 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
6238 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
6239
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6240 return status;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6241 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6242
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6243 /*
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6244 * 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
6245 * 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
6246 * 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
6247 */
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6248 static int
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6249 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
6250 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
6251 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
6252 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
6253 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
6254 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
6255 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6256 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
6257 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
6258 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
6259 long lnum;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6260
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6261 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
6262 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
6263
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
6264 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
6265 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
6266 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
6267 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
6268 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
6269 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
6270 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
6271 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
6272 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
6273 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
6274 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
6275 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
6276
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6277 valid = TRUE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6278 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
6279 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6280
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6281 // 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
6282 // 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
6283 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
6284 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6285 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
6286 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6287 did_bufnr_emsg = TRUE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6288 EMSGN(_("E92: Buffer %ld not found"), bufnum);
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 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6291 bufnum = 0;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6292 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6293
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6294 // 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
6295 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
6296 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
6297
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6298 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
6299 qf_idx,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6300 NULL, // dir
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6301 filename,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6302 module,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6303 bufnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6304 text,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6305 lnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6306 col,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6307 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
6308 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
6309 nr,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6310 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
6311 valid);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6312
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6313 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
6314 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
6315 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
6316 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
6317 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
6318
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6319 if (valid)
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6320 *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
6321
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6322 return status;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6323 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6324
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6325 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6326 * 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
6327 * a dictionary with item information.
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6328 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6329 static int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6330 qf_add_entries(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6331 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
6332 int qf_idx,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6333 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6334 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6335 int action)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6336 {
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
6337 qf_list_T *qfl = &qi->qf_lists[qf_idx];
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6338 listitem_T *li;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6339 dict_T *d;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
6340 qfline_T *old_last = NULL;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6341 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
6342 int valid_entry = FALSE;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6343
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6344 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
6345 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6346 // make place for a new list
3965
eccae034465b updated for version 7.3.738
Bram Moolenaar <bram@vim.org>
parents: 3949
diff changeset
6347 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
6348 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
6349 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
6350 }
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
6351 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
6352 // 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
6353 old_last = qfl->qf_last;
277
fe16c18c24a7 updated for version 7.0074
vimboss
parents: 273
diff changeset
6354 else if (action == 'r')
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6355 {
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
6356 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
6357 qf_store_title(qfl, title);
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6358 }
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 for (li = list->lv_first; li != NULL; li = li->li_next)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6361 {
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6362 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
6363 continue; // Skip non-dict items
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6364
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6365 d = li->li_tv.vval.v_dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6366 if (d == NULL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6367 continue;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6368
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6369 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
6370 &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
6371 if (retval == FAIL)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6372 break;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6373 }
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6374
15225
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6375 // 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
6376 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
6377 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
6378 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
6379 // 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
6380 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
6381
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6382 // 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
6383 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
6384 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
6385
a413374825dd patch 8.1.0622: adding quickfix items marks items as valid errors
Bram Moolenaar <Bram@vim.org>
parents: 15146
diff changeset
6386 // 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
6387 // 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
6388 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
6389 qfl->qf_index = 1;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6390
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6391 // 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
6392 qf_update_buffer(qi, old_last);
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6393
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6394 return retval;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6395 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6396
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6397 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6398 * 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
6399 */
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6400 static int
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6401 qf_setprop_get_qfidx(
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6402 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6403 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6404 int action,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6405 int *newlist)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6406 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6407 dictitem_T *di;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6408 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
6409
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6410 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
6411 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6412 // 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
6413 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
6414 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6415 // 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
6416 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
6417 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
6418
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6419 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
6420 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6421 // 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
6422 // 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
6423 // stack.
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6424 *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
6425 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
6426 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6427 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
6428 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
6429 else if (action != ' ')
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6430 *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
6431 }
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6432 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
6433 && 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
6434 && 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
6435 {
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6436 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
6437 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
6438 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
6439 qf_idx = 0;
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6440 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6441 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
6442 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6443 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6444 return INVALID_QFIDX;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6445 }
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 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
6448 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6449 // 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
6450 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
6451 return INVALID_QFIDX;
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 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
6454 }
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 return qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6457 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6458
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6459 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6460 * 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
6461 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6462 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6463 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
6464 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6465 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
6466
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6467 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
6468 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6469
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6470 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
6471 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
6472 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
6473 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
6474
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6475 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6476 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6477
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6478 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6479 * 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
6480 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6481 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6482 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
6483 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6484 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6485 char_u *title_save;
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 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
6488 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6489
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6490 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
6491 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
6492 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
6493 vim_free(title_save);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6494
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6495 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6496 }
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 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6499 * 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
6500 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6501 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6502 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
6503 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6504 int qf_idx,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6505 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6506 dictitem_T *di,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6507 int action)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6508 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6509 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
6510 dictitem_T *efm_di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6511 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6512
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6513 // 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
6514 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
6515 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6516 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
6517 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
6518 return FAIL;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6519 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
6520 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6521
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6522 // 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
6523 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
6524 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6525
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6526 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
6527 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
6528 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
6529 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
6530 retval = OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6531
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6532 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6533 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6534
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6535 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6536 * Set quickfix list context.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6537 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6538 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
6539 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
6540 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6541 typval_T *ctx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6542
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
6543 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
6544 ctx = alloc_tv();
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6545 if (ctx != NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6546 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
6547 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
6548
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6549 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6550 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6551
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6552 /*
15424
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6553 * 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
6554 */
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6555 static int
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6556 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
6557 {
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6558 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
6559 int newidx;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6560 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
6561 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
6562
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6563 // 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
6564 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
6565 && 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
6566 && 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
6567 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
6568 else
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6569 {
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6570 // 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
6571 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
6572 if (denote)
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6573 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6574 }
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6575
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6576 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
6577 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6578 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
6579 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
6580
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6581 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
6582 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
6583 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
6584 return FAIL;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6585 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
6586 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
6587
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6588 // 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
6589 // 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
6590 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
6591 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
6592
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6593 return OK;
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6594 }
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6595
90c8ff9c19ee patch 8.1.0720: cannot easily change the current quickfx list index
Bram Moolenaar <Bram@vim.org>
parents: 15225
diff changeset
6596 /*
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6597 * 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
6598 * 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
6599 * 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
6600 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6601 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6602 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
6603 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6604 dictitem_T *di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6605 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6606 int qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6607 int newlist = FALSE;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6608 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
6609
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6610 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
6611 newlist = TRUE;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6612
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6613 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
6614 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
6615 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
6616
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6617 if (newlist)
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6618 {
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6619 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
6620 qf_new_list(qi, title);
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6621 qf_idx = qi->qf_curlist;
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6622 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6623
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6624 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
6625 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
6626 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
6627 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
6628 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
6629 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
6630 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
6631 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
6632 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
6633 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
6634 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
6635
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6636 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6637 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
6638
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6639 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6640 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6641
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6642 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6643 * 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
6644 * 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
6645 */
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6646 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
6647 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
6648 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6649 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
6650
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6651 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
6652 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
6653 return wp;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6654
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6655 return NULL;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6656 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6657
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6658 /*
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6659 * 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
6660 * 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
6661 */
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6662 static void
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6663 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
6664 {
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6665 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
6666 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
6667 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
6668
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6669 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
6670 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6671 // 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
6672 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
6673 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
6674 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
6675 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6676
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6677 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
6678 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6679 // 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
6680 // 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
6681 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
6682 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
6683 wp = llwin;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6684 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6685
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6686 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
6687 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
6688 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6689 // 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
6690 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
6691 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
6692 }
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6693 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
6694 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6695 // 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
6696 // location list
15042
e95e8b356a65 patch 8.1.0532: cannot distinguish between quickfix and location list
Bram Moolenaar <Bram@vim.org>
parents: 15024
diff changeset
6697 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
6698
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6699 // 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
6700 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
6701
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6702 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
6703 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
6704 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6705 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
6706 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
6707 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6708 }
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6709 }
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6710
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6711 /*
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6712 * 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
6713 * 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
6714 * "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
6715 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6716 int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6717 set_errorlist(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6718 win_T *wp,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6719 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6720 int action,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6721 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6722 dict_T *what)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6723 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6724 qf_info_T *qi = &ql_info;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6725 int retval = OK;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6726
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6727 if (wp != NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6728 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6729 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
6730 if (qi == NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6731 return FAIL;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6732 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6733
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6734 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
6735 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6736 // 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
6737 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
6738 return OK;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6739 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6740
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6741 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6742
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6743 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
6744 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
6745 else
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6746 {
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6747 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
6748 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6749 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
6750 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6751
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6752 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6753
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6754 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6755 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6756
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6757 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6758 * 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
6759 */
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6760 static int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6761 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
6762 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6763 int i;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6764 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6765 typval_T *ctx;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6766
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6767 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
6768 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6769 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
6770 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
6771 && 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
6772 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
6773 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6774
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6775 return abort;
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 /*
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6779 * 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
6780 * "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
6781 */
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6782 int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6783 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
6784 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6785 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6786 tabpage_T *tp;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6787 win_T *win;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6788
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6789 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
6790 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6791 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6792
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6793 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
6794 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6795 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
6796 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6797 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
6798 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6799 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6800 }
13074
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6801 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
6802 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6803 // 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
6804 // 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
6805 // 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
6806 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
6807 if (abort)
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6808 return abort;
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6809 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6810 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6811
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6812 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6813 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6814 #endif
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6815
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
6816 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6817 * ":[range]cbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6818 * ":[range]caddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6819 * ":[range]cgetbuffer [bufnr]" command.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6820 * ":[range]lbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6821 * ":[range]laddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6822 * ":[range]lgetbuffer [bufnr]" command.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6823 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6824 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6825 ex_cbuffer(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6826 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6827 buf_T *buf = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6828 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
6829 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
6830 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
6831 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
6832 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6833
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6834 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6835 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6836 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
6837 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
6838 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
6839 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
6840 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
6841 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
6842 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6843 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6844 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
6845 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6846 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6847 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6848 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6849 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6850 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6851 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6852
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6853 // 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
6854 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
6855 {
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6856 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
6857 if (qi == NULL)
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6858 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6859 wp = curwin;
13076
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6860 }
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6861
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6862 if (*eap->arg == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6863 buf = curbuf;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6864 else if (*skipwhite(skipdigits(eap->arg)) == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6865 buf = buflist_findnr(atoi((char *)eap->arg));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6866 if (buf == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6867 EMSG(_(e_invarg));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6868 else if (buf->b_ml.ml_mfp == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6869 EMSG(_("E681: Buffer is not loaded"));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6870 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6871 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6872 if (eap->addr_count == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6873 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6874 eap->line1 = 1;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6875 eap->line2 = buf->b_ml.ml_line_count;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6876 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6877 if (eap->line1 < 1 || eap->line1 > buf->b_ml.ml_line_count
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6878 || eap->line2 < 1 || eap->line2 > buf->b_ml.ml_line_count)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6879 EMSG(_(e_invrange));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6880 else
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6881 {
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
6882 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
6883
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6884 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
6885 {
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6886 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
6887 (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
6888 qf_title = IObuff;
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6889 }
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6890
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6891 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6892
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6893 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
6894 (eap->cmdidx != CMD_caddbuffer
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6895 && 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
6896 eap->line1, eap->line2,
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6897 qf_title, NULL);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6898 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
6899 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6900 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6901 return;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6902 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6903 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6904 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
6905
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6906 // 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
6907 // 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
6908 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
6909 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
6910 {
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6911 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
6912
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6913 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
6914 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
6915 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
6916 // 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
6917 // be invalid.
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6918 res = 0;
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6919 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6920 // 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
6921 // free the list.
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6922 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
6923 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
6924 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6925 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6926 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
6927
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6928 decr_quickfix_busy();
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6929 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6930 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6931 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6932
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
6933 #if defined(FEAT_EVAL) || defined(PROTO)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6934 /*
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6935 * ":cexpr {expr}", ":cgetexpr {expr}", ":caddexpr {expr}" command.
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6936 * ":lexpr {expr}", ":lgetexpr {expr}", ":laddexpr {expr}" command.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6937 */
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6938 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6939 ex_cexpr(exarg_T *eap)
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6940 {
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6941 typval_T *tv;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6942 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
6943 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
6944 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
6945 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
6946 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6947
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6948 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6949 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6950 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
6951 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
6952 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
6953 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
6954 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
6955 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
6956 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6957 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6958 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
6959 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6960 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6961 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6962 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6963 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6964 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6965 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6966
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
6967 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
6968 {
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6969 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
6970 if (qi == NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6971 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6972 wp = curwin;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6973 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6974
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6975 // 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
6976 // use it to fill the errorlist.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6977 tv = eval_expr(eap->arg, NULL);
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6978 if (tv != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6979 {
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6980 if ((tv->v_type == VAR_STRING && tv->vval.v_string != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6981 || (tv->v_type == VAR_LIST && tv->vval.v_list != NULL))
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6982 {
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6983 incr_quickfix_busy();
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6984 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
6985 (eap->cmdidx != CMD_caddexpr
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6986 && 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
6987 (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
6988 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
6989 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
6990 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6991 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6992 goto cleanup;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6993 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6994 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6995 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
6996
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6997 // 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
6998 // 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
6999 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
7000 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
7001 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
7002 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
7003
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
7004 // 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
7005 // free the list.
14111
678e326bf7eb patch 8.1.0073: crash when autocommands call setloclist()
Christian Brabandt <cb@256bit.org>
parents: 14085
diff changeset
7006 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
7007 || 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
7008 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
7009 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
7010 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
7011 decr_quickfix_busy();
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
7012 }
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
7013 else
626
732c7ae5743e updated for version 7.0180
vimboss
parents: 625
diff changeset
7014 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
7015 cleanup:
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
7016 free_tv(tv);
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
7017 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
7018 }
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
7019 #endif
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
7020
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
7021 /*
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7022 * 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
7023 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7024 static qf_info_T *
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7025 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
7026 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7027 win_T *wp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7028 qf_info_T *qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7029
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7030 // 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
7031 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
7032 wp = curwin;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7033 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7034 // 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
7035 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
7036
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7037 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
7038 qi = NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7039 else
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7040 qi = wp->w_llist;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7041
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7042 if (qi == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7043 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7044 // 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
7045 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
7046 return NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7047 *new_ll = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7048 }
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 return qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7051 }
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 /*
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7054 * 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
7055 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7056 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7057 hgr_search_file(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7058 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7059 char_u *fname,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7060 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7061 vimconv_T *p_vc,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7062 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7063 regmatch_T *p_regmatch)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7064 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7065 FILE *fd;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7066 long lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7067
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7068 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
7069 if (fd == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7070 return;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7071
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7072 lnum = 1;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7073 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
7074 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7075 char_u *line = IObuff;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7076 #ifdef FEAT_MBYTE
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7077 // 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
7078 // 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
7079 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
7080 && has_non_ascii(IObuff))
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 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
7083 if (line == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7084 line = IObuff;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7085 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7086 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7087
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7088 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
7089 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7090 int l = (int)STRLEN(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7091
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7092 // 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
7093 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
7094 line[--l] = NUL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7095
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7096 if (qf_add_entry(qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7097 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7098 NULL, // dir
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7099 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
7100 NULL,
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7101 0,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7102 line,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7103 lnum,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7104 (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
7105 + 1, // col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7106 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7107 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7108 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7109 1, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7110 TRUE // valid
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7111 ) == FAIL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7112 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7113 got_int = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7114 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7115 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7116 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7117 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7118 break;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7119 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7120 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7121 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7122 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7123 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7124 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7125 ++lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7126 line_breakcheck();
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7127 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7128 fclose(fd);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7129 }
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 /*
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7132 * 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
7133 * the given directory.
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 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7136 hgr_search_files_in_dir(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7137 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7138 char_u *dirname,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7139 regmatch_T *p_regmatch
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7140 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7141 , vimconv_T *p_vc
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7142 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7143 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7144 , char_u *lang
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7145 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7146 )
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7147 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7148 int fcount;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7149 char_u **fnames;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7150 int fi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7151
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7152 // 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
7153 add_pathsep(dirname);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7154 STRCAT(dirname, "doc/*.\\(txt\\|??x\\)");
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7155 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
7156 &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
7157 && fcount > 0)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7158 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7159 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
7160 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7161 #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
7162 // 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
7163 if (lang != NULL
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7164 && 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
7165 + 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
7166 && !(STRNICMP(lang, "en", 2) == 0
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7167 && STRNICMP("txt", fnames[fi]
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7168 + 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
7169 continue;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7170 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7171
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7172 hgr_search_file(qi, fnames[fi],
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7173 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7174 p_vc,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7175 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7176 p_regmatch);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7177 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7178 FreeWild(fcount, fnames);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7179 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7180 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7181
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7182 /*
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
7183 * 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
7184 * 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
7185 * '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
7186 * specified language are found.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7187 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7188 static void
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7189 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
7190 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7191 char_u *p;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7192
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7193 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7194 vimconv_T vc;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7195
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7196 // 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
7197 // differs.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7198 vc.vc_type = CONV_NONE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7199 if (!enc_utf8)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7200 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
7201 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7202
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7203 // 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
7204 p = p_rtp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7205 while (*p != NUL && !got_int)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7206 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7207 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
7208
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7209 hgr_search_files_in_dir(qi, NameBuff, p_regmatch
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7210 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7211 , &vc
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7212 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7213 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7214 , lang
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7215 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7216 );
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7217 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7218
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7219 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7220 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
7221 convert_setup(&vc, NULL, NULL);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7222 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7223 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7224
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7225 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7226 * ":helpgrep {pattern}"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7227 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7228 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
7229 ex_helpgrep(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7230 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7231 regmatch_T regmatch;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7232 char_u *save_cpo;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
7233 qf_info_T *qi = &ql_info;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7234 int new_qi = FALSE;
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7235 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
7236 char_u *lang = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7237
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7238 switch (eap->cmdidx)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7239 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7240 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
7241 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
7242 default: break;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7243 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7244 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
7245 curbuf->b_fname, TRUE, curbuf))
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7246 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7247 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7248 if (aborting())
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7249 return;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7250 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7251 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7252
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7253 // 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
7254 save_cpo = p_cpo;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7255 p_cpo = empty_option;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7256
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
7257 if (is_loclist_cmd(eap->cmdidx))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7258 {
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7259 qi = hgr_get_ll(&new_qi);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7260 if (qi == NULL)
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7261 return;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7262 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7263
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7264 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7265
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7266 #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
7267 // 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
7268 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
7269 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7270 regmatch.regprog = vim_regcomp(eap->arg, RE_MAGIC + RE_STRING);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7271 regmatch.rm_ic = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7272 if (regmatch.regprog != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7273 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7274 qf_list_T *qfl;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7275
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7276 // 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
7277 qf_new_list(qi, qf_cmdtitle(*eap->cmdlinep));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7278
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7279 hgr_search_in_rtp(qi, &regmatch, lang);
3257
75217982ea46 updated for version 7.3.397
Bram Moolenaar <bram@vim.org>
parents: 3242
diff changeset
7280
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
7281 vim_regfree(regmatch.regprog);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7282
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7283 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
7284 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7285 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
7286 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7287 qf_list_changed(qfl);
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7288 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7289 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7290
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7291 if (p_cpo == empty_option)
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7292 p_cpo = save_cpo;
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7293 else
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7294 // Darn, some plugin changed the value.
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7295 free_string_option(save_cpo);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7296
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7297 if (au_name != NULL)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7298 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7299 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7300 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
7301 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
7302 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7303 // 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
7304 decr_quickfix_busy();
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7305 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7306 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7307 }
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7308
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7309 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
7310 if (!qf_list_empty(qi, qi->qf_curlist))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7311 qf_jump(qi, 0, 0, FALSE);
9
4102fb4ea781 updated for version 7.0002
vimboss
parents: 7
diff changeset
7312 else
4102fb4ea781 updated for version 7.0002
vimboss
parents: 7
diff changeset
7313 EMSG2(_(e_nomatch2), eap->arg);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7314
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7315 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7316
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7317 if (eap->cmdidx == CMD_lhelpgrep)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7318 {
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7319 // 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
7320 // 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
7321 if (!bt_help(curwin->w_buffer) || curwin->w_llist == qi)
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7322 {
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7323 if (new_qi)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7324 ll_free_all(&qi);
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7325 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7326 else if (curwin->w_llist == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7327 curwin->w_llist = qi;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7328 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7329 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7330
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7331 #endif /* FEAT_QUICKFIX */