annotate src/quickfix.c @ 14976:676db1b7fc35 v8.1.0499

patch 8.1.0499: :2vimgrep causes an ml_get error commit https://github.com/vim/vim/commit/1c29943416207e21abbc790eaf563b36789170c2 Author: Bram Moolenaar <Bram@vim.org> Date: Sun Oct 28 14:36:09 2018 +0100 patch 8.1.0499: :2vimgrep causes an ml_get error Problem: :2vimgrep causes an ml_get error Solution: Pass tomatch pointer instead of value. (Yegappan Lakshmanan)
author Bram Moolenaar <Bram@vim.org>
date Sun, 28 Oct 2018 14:45:05 +0100
parents 940def6df43f
children 3a3c9b638187
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 /*
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
53 * 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
54 * 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
55 * 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
56 *
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
57 * 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
58 * 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
59 * 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
60 */
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
61 typedef struct qf_list_S
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
62 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
63 int_u qf_id; // Unique identifier for this list
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
64 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
65 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
66 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
67 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
68 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
69 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
70 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
71 // 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
72 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
73
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
74 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
75 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
76 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
77 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
78 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
79 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
80 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
81 long qf_changedtick;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
82 } qf_list_T;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
83
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
84 /*
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
85 * 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
86 * 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
87 */
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
88 struct qf_info_S
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
89 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
90 // 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
91 // 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
92 // 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
93 // reaches 0, the list is freed.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
94 int qf_refcount;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
95 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
96 int qf_curlist; // current error list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
97 qf_list_T qf_lists[LISTCOUNT];
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
98 };
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
99
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
100 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
101 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
102
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
103 #define FMT_PATTERNS 11 // maximum number of % recognized
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
104
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
105 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
106 * Structure used to hold the info of one part of 'errorformat'
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
107 */
789
b29b006d52d2 updated for version 7.0230
vimboss
parents: 729
diff changeset
108 typedef struct efm_S efm_T;
b29b006d52d2 updated for version 7.0230
vimboss
parents: 729
diff changeset
109 struct efm_S
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
110 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
111 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
112 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
113 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
114 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
115 // 'D' enter directory
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
116 // 'X' leave directory
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
117 // '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
118 // 'E' error message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
119 // 'W' warning message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
120 // 'I' informational message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
121 // 'C' continuation line
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
122 // '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
123 // 'G' general, unspecific message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
124 // '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
125 // '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
126 // 'O' overread (partial) message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
127 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
128 // '-' 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
129 // '+' 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
130 int conthere; // %> used
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
131 };
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
132
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
133 // 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
134 // 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
135 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
136 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
137 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
138 qf_info_T *qi;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
139 } qf_delq_T;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
140 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
141
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
142 // 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
143 // still being used.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
144 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
145
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
146 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
147
7805
0b6c37dd858d commit https://github.com/vim/vim/commit/baaa7e9ec7398a813e21285c272fa99792642077
Christian Brabandt <cb@256bit.org>
parents: 7710
diff changeset
148 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
149 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
150 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
151 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
152 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
153 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
154 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
155 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
156 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
157 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
158 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
159 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
160 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
161 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
162 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
163 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
164 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
165 static qf_info_T *ll_get_or_alloc_list(win_T *);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
166
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
167 // Quickfix window check helper macro
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
168 #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
169 // Location list window check helper macro
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
170 #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
171
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
172 // Quickfix and location list stack check helper macros
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
173 #define IS_QF_STACK(qi) (qi == &ql_info)
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
174 #define IS_LL_STACK(qi) (qi != &ql_info)
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
175
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
176 /*
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
177 * Return location list for window 'wp'
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
178 * For location list window, return the referenced location list
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
179 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
180 #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
181
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
182 /*
11443
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
183 * 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
184 * 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
185 */
11447
698ee9d4fe9f patch 8.0.0607: after :bwipe + :new bufref might still be valid
Christian Brabandt <cb@256bit.org>
parents: 11445
diff changeset
186 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
187 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
188
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
189 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
190 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
191
11443
30b3775addb2 patch 8.0.0605: the quickfix cached buffer may become invalid
Christian Brabandt <cb@256bit.org>
parents: 11426
diff changeset
192 /*
9033
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
193 * 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
194 */
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
195 #define LINE_MAXLEN 4096
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
196
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
197 static struct fmtpattern
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
198 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
199 char_u convchar;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
200 char *pattern;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
201 } 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
202 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
203 {'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
204 {'n', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
205 {'l', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
206 {'c', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
207 {'t', "."},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
208 {'m', ".\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
209 {'r', ".*"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
210 {'p', "[- .]*"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
211 {'v', "\\d\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
212 {'s', ".\\+"},
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
213 {'o', ".\\+"}
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
214 };
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
215
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
216 /*
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
217 * 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
218 * 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
219 * 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
220 * 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
221 */
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
222 static char_u *
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
223 efmpat_to_regpat(
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
224 char_u *efmpat,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
225 char_u *regpat,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
226 efm_T *efminfo,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
227 int idx,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
228 int round,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
229 char_u *errmsg)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
230 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
231 char_u *srcptr;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
232
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
233 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
234 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
235 // 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
236 sprintf((char *)errmsg,
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
237 _("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
238 EMSG(errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
239 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
240 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
241 if ((idx && idx < 6
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
242 && 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
243 || (idx == 6
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
244 && 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
245 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
246 sprintf((char *)errmsg,
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
247 _("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
248 EMSG(errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
249 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
250 }
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
251 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
252 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
253 *regpat++ = '(';
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
254 #ifdef BACKSLASH_IN_FILENAME
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
255 if (*efmpat == 'f')
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
256 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
257 // 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
258 // 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
259 // "\%(\a:\)\="
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
260 STRCPY(regpat, "\\%(\\a:\\)\\=");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
261 regpat += 10;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
262 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
263 #endif
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
264 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
265 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
266 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
267 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
268 // 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
269 // 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
270 // 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
271 // 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
272 // follows should work.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
273 STRCPY(regpat, ".\\{-1,}");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
274 regpat += 7;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
275 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
276 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
277 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
278 // 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
279 // 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
280 STRCPY(regpat, "\\f\\+");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
281 regpat += 4;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
282 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
283 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
284 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
285 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
286 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
287 while ((*regpat = *srcptr++) != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
288 ++regpat;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
289 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
290 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
291 *regpat++ = ')';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
292
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
293 return regpat;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
294 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
295
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 * 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
298 * 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
299 */
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
300 static char_u *
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
301 scanf_fmt_to_regpat(
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
302 char_u **pefmp,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
303 char_u *efm,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
304 int len,
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
305 char_u *regpat,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
306 char_u *errmsg)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
307 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
308 char_u *efmp = *pefmp;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
309
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
310 if (*efmp == '[' || *efmp == '\\')
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
311 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
312 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
313 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
314 if (efmp[1] == '^')
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
315 *regpat++ = *++efmp;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
316 if (efmp < efm + len)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
317 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
318 *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
319 while (efmp < efm + len
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
320 && (*regpat++ = *++efmp) != ']')
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
321 // skip ;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
322 if (efmp == efm + len)
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
323 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
324 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
325 return NULL;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
326 }
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 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
329 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
330 *regpat++ = *++efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
331 *regpat++ = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
332 *regpat++ = '+';
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
333 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
334 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
335 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
336 // 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
337 sprintf((char *)errmsg,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
338 _("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
339 EMSG(errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
340 return NULL;
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
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
343 *pefmp = efmp;
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
344
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
345 return regpat;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
346 }
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
347
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
348 /*
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
349 * 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
350 */
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
351 static char_u *
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
352 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
353 {
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
354 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
355 efminfo->flags = *efmp++;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
356 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
357 efminfo->prefix = *efmp;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
358 else
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
359 {
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
360 sprintf((char *)errmsg,
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
361 _("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
362 EMSG(errmsg);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
363 return NULL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
364 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
365
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
366 return efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
367 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
368
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
369 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
370 * 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
371 * 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
372 * 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
373 * Returns OK or FAIL.
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
374 */
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
375 static int
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
376 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
377 char_u *efm,
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
378 int len,
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
379 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
380 char_u *regpat,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
381 char_u *errmsg)
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
382 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
383 char_u *ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
384 char_u *efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
385 int round;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
386 int idx = 0;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
387
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
388 // 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
389 ptr = regpat;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
390 *ptr++ = '^';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
391 round = 0;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
392 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
393 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
394 if (*efmp == '%')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
395 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
396 ++efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
397 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
398 if (fmt_pat[idx].convchar == *efmp)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
399 break;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
400 if (idx < FMT_PATTERNS)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
401 {
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
402 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
403 errmsg);
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
404 if (ptr == NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
405 return FAIL;
13984
9b1dc5c2f460 patch 8.1.0010: efm_to_regpat() is too long
Christian Brabandt <cb@256bit.org>
parents: 13948
diff changeset
406 round++;
9365
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 else if (*efmp == '*')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
409 {
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
410 ++efmp;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
411 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
412 if (ptr == NULL)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
413 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
414 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
415 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
416 *ptr++ = *efmp; // regexp magic characters
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
417 else if (*efmp == '#')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
418 *ptr++ = '*';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
419 else if (*efmp == '>')
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
420 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
421 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
422 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
423 // 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
424 // option part
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
425 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
426 if (efmp == NULL)
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
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
430 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
431 sprintf((char *)errmsg,
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
432 _("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
433 EMSG(errmsg);
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
434 return FAIL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
435 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
436 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
437 else // copy normal character
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
438 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
439 if (*efmp == '\\' && efmp + 1 < efm + len)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
440 ++efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
441 else if (vim_strchr((char_u *)".*^$~[", *efmp) != NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
442 *ptr++ = '\\'; // escape regexp atoms
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
443 if (*efmp)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
444 *ptr++ = *efmp;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
445 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
446 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
447 *ptr++ = '$';
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
448 *ptr = NUL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
449
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
450 return OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
451 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
452
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
453 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
454 * Free the 'errorformat' information list
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
455 */
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
456 static void
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
457 free_efm_list(efm_T **efm_first)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
458 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
459 efm_T *efm_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
460
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
461 for (efm_ptr = *efm_first; efm_ptr != NULL; efm_ptr = *efm_first)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
462 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
463 *efm_first = efm_ptr->next;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
464 vim_regfree(efm_ptr->prog);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
465 vim_free(efm_ptr);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
466 }
10367
4e4e116e3689 commit https://github.com/vim/vim/commit/63bed3d319b5d90765dbdae93a3579b6322d79fb
Christian Brabandt <cb@256bit.org>
parents: 10359
diff changeset
467 fmt_start = NULL;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
468 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
469
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
470 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
471 * Compute the size of the buffer used to convert a 'errorformat' pattern into
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
472 * a regular expression pattern.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
473 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
474 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
475 efm_regpat_bufsz(char_u *efm)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
476 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
477 int sz;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
478 int i;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
479
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
480 sz = (FMT_PATTERNS * 3) + ((int)STRLEN(efm) << 2);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
481 for (i = FMT_PATTERNS; i > 0; )
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
482 sz += (int)STRLEN(fmt_pat[--i].pattern);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
483 #ifdef BACKSLASH_IN_FILENAME
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
484 sz += 12; // "%f" can become twelve chars longer (see efm_to_regpat)
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
485 #else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
486 sz += 2; // "%f" can become two chars longer
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
487 #endif
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
488
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
489 return sz;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
490 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
491
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
492 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
493 * Return the length of a 'errorformat' option part (separated by ",").
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
494 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
495 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
496 efm_option_part_len(char_u *efm)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
497 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
498 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
499
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
500 for (len = 0; efm[len] != NUL && efm[len] != ','; ++len)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
501 if (efm[len] == '\\' && efm[len + 1] != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
502 ++len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
503
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
504 return len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
505 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
506
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
507 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
508 * Parse the 'errorformat' option. Multiple parts in the 'errorformat' option
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
509 * are parsed and converted to regular expressions. Returns information about
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
510 * the parsed 'errorformat' option.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
511 */
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
512 static efm_T *
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
513 parse_efm_option(char_u *efm)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
514 {
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
515 char_u *errmsg = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
516 int errmsglen;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
517 efm_T *fmt_ptr = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
518 efm_T *fmt_first = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
519 efm_T *fmt_last = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
520 char_u *fmtstr = NULL;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
521 int len;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
522 int sz;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
523
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
524 errmsglen = CMDBUFFSIZE + 1;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
525 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
526 if (errmsg == NULL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
527 goto parse_efm_end;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
528
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
529 // 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
530 // 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
531
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
532 // 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
533 sz = efm_regpat_bufsz(efm);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
534 if ((fmtstr = alloc(sz)) == NULL)
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
535 goto parse_efm_error;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
536
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
537 while (efm[0] != NUL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
538 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
539 // 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
540 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
541 if (fmt_ptr == NULL)
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
542 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
543 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
544 fmt_first = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
545 else
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
546 fmt_last->next = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
547 fmt_last = fmt_ptr;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
548
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
549 // 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
550 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
551
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
552 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
553 goto parse_efm_error;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
554 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
555 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
556 // Advance to next part
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
557 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
558 }
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
559
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
560 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
561 EMSG(_("E378: 'errorformat' contains no pattern"));
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
562
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
563 goto parse_efm_end;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
564
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
565 parse_efm_error:
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
566 free_efm_list(&fmt_first);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
567
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
568 parse_efm_end:
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
569 vim_free(fmtstr);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
570 vim_free(errmsg);
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
571
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
572 return fmt_first;
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
573 }
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
diff changeset
574
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
575 enum {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
576 QF_FAIL = 0,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
577 QF_OK = 1,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
578 QF_END_OF_INPUT = 2,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
579 QF_NOMEM = 3,
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
580 QF_IGNORE_LINE = 4,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
581 QF_MULTISCAN = 5,
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
582 };
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
583
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
584 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
585 * 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
586 * list.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
587 */
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
588 typedef struct {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
589 char_u *linebuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
590 int linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
591 char_u *growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
592 int growbufsiz;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
593 FILE *fd;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
594 typval_T *tv;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
595 char_u *p_str;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
596 listitem_T *p_li;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
597 buf_T *buf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
598 linenr_T buflnum;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
599 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
600 vimconv_T vc;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
601 } qfstate_T;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
602
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
603 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
604 * 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
605 */
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
606 static char_u *
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
607 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
608 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
609 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
610
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
611 // 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
612 // 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
613 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
614 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
615 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
616 state->growbuf = alloc(state->linelen + 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
617 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
618 return NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
619 state->growbufsiz = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
620 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
621 else if (state->linelen > state->growbufsiz)
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 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
624 return NULL;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
625 state->growbuf = p;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
626 state->growbufsiz = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
627 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
628 return state->growbuf;
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
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
631 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
632 * 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
633 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
634 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
635 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
636 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
637 // 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
638 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
639 char_u *p;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
640 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
641
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
642 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
643 return QF_END_OF_INPUT;
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 p = vim_strchr(p_str, '\n');
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
646 if (p != NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
647 len = (int)(p - p_str) + 1;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
648 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
649 len = (int)STRLEN(p_str);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
650
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
651 if (len > IOSIZE - 2)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
652 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
653 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
654 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
655 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
656 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
657 else
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 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
660 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
661 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
662 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
663
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
664 // 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
665 // 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
666 p_str += len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
667 state->p_str = p_str;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
668
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
669 return QF_OK;
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
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 * 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
674 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
675 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
676 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
677 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
678 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
679 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
680
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
681 while (p_li != NULL
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
682 && (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
683 || 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
684 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
685
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
686 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
687 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
688 state->p_li = NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
689 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
690 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
691
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
692 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
693 if (len > IOSIZE - 2)
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 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
696 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
697 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
698 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
699 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
700 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
701 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
702 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
703 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
704
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
705 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
706
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
707 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
708 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
709 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
710
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
711 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
712 * 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
713 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
714 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
715 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
716 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
717 char_u *p_buf = NULL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
718 int len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
719
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
720 // 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
721 if (state->buflnum > state->lnumlast)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
722 return QF_END_OF_INPUT;
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 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
725 state->buflnum += 1;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
726
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
727 len = (int)STRLEN(p_buf);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
728 if (len > IOSIZE - 2)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
729 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
730 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
731 if (state->linebuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
732 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
733 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
734 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
735 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
736 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
737 state->linelen = len;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
738 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
739 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
740
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
741 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
742 }
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 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
745 * 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
746 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
747 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
748 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
749 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
750 int discard;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
751 int growbuflen;
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 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
754 return QF_END_OF_INPUT;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
755
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
756 discard = FALSE;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
757 state->linelen = (int)STRLEN(IObuff);
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
758 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
759 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
760 // 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
761 // 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
762 if (state->growbuf == NULL)
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 state->growbufsiz = 2 * (IOSIZE - 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
765 state->growbuf = alloc(state->growbufsiz);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
766 if (state->growbuf == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
767 return QF_NOMEM;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
768 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
769
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
770 // 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
771 memcpy(state->growbuf, IObuff, IOSIZE - 1);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
772 growbuflen = state->linelen;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
773
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
774 for (;;)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
775 {
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
776 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
777
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
778 if (fgets((char *)state->growbuf + growbuflen,
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
779 state->growbufsiz - growbuflen, state->fd) == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
780 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
781 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
782 growbuflen += state->linelen;
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
783 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
784 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
785 if (state->growbufsiz == LINE_MAXLEN)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
786 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
787 discard = TRUE;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
788 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
789 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
790
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
791 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
792 ? 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
793 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
794 return QF_NOMEM;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
795 state->growbuf = p;
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
796 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
797
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
798 while (discard)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
799 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
800 // 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
801 // 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
802 // reached.
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
803 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
804 || (int)STRLEN(IObuff) < IOSIZE - 1
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
805 || IObuff[IOSIZE - 1] == '\n')
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
806 break;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
807 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
808
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
809 state->linebuf = state->growbuf;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
810 state->linelen = growbuflen;
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 else
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
813 state->linebuf = IObuff;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
814
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
815 #ifdef FEAT_MBYTE
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
816 // 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
817 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
818 {
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
819 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
820
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
821 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
822 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
823 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
824 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
825 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
826 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
827 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
828 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
829 else
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
830 {
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
831 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
832 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
833 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
834 ? 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
835 }
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
836 }
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 #endif
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
839
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
840 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
841 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
842
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
843 /*
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
844 * 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
845 */
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
846 static int
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
847 qf_get_nextline(qfstate_T *state)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
848 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
849 int status = QF_FAIL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
850
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
851 if (state->fd == NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
852 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
853 if (state->tv != NULL)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
854 {
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
855 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
856 // 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
857 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
858 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
859 // 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
860 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
861 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
862 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
863 // 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
864 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
865 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
866 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
867 // 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
868 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
869
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
870 if (status != QF_OK)
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
871 return status;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
872
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
873 // 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
874 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
875 {
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
876 state->linebuf[state->linelen - 1] = NUL;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
877 #ifdef USE_CRNL
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
878 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
879 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
880 #endif
9738
6818e3c96473 commit https://github.com/vim/vim/commit/796aa9c804f09276bd3cc45123f4a191a001dec2
Christian Brabandt <cb@256bit.org>
parents: 9649
diff changeset
881 }
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
882
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
883 #ifdef FEAT_MBYTE
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
884 remove_bom(state->linebuf);
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
885 #endif
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
886
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
887 return QF_OK;
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
888 }
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
889
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
890 typedef struct {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
891 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
892 char_u *module;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
893 char_u *errmsg;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
894 int errmsglen;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
895 long lnum;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
896 int col;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
897 char_u use_viscol;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
898 char_u *pattern;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
899 int enr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
900 int type;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
901 int valid;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
902 } qffields_T;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
903
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
904 /*
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
905 * 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
906 * 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
907 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
908 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
909 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
910 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
911 int c;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
912
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
913 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
914 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
915
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
916 // 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
917 c = *rmp->endp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
918 *rmp->endp[midx] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
919 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
920 *rmp->endp[midx] = c;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
921
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
922 // 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
923 // should exist.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
924 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
925 && mch_getperm(fields->namebuf) == -1)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
926 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
927
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
928 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
929 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
930
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
931 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
932 * 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
933 * 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
934 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
935 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
936 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
937 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
938 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
939 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
940 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
941 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
942 }
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 * 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
946 * 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
947 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
948 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
949 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
950 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
951 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
952 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
953 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
954 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
955 }
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 * 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
959 * 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
960 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
961 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
962 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
963 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
964 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
965 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
966 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
967 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
968 }
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 * 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
972 * 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
973 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
974 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
975 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
976 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
977 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
978 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
979 fields->type = *rmp->startp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
980 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
981 }
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 * 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
985 * 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
986 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
987 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
988 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
989 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
990 char_u *p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
991
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
992 if (linelen >= fields->errmsglen)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
993 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
994 // linelen + null terminator
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
995 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
996 return QF_NOMEM;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
997 fields->errmsg = p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
998 fields->errmsglen = linelen + 1;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
999 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1000 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
1001 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1002 }
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 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1005 * 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
1006 * 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
1007 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1008 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1009 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
1010 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1011 char_u *p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1012 int len;
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 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
1015 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1016 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
1017 if (len >= fields->errmsglen)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1018 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1019 // len + null terminator
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1020 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
1021 return QF_NOMEM;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1022 fields->errmsg = p;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1023 fields->errmsglen = len + 1;
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 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
1026 return QF_OK;
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
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1029 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1030 * 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
1031 * 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
1032 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1033 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1034 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
1035 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1036 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1037 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1038 *tail = rmp->startp[midx];
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1039 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1040 }
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 * 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
1044 * 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
1045 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1046 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1047 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
1048 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1049 char_u *match_ptr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1050
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1051 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
1052 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1053 fields->col = 0;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1054 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
1055 ++match_ptr)
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 ++fields->col;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1058 if (*match_ptr == TAB)
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 fields->col += 7;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1061 fields->col -= fields->col % 8;
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 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1064 ++fields->col;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1065 fields->use_viscol = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1066 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1067 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1068
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1069 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1070 * 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
1071 * 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
1072 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1073 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1074 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
1075 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1076 if (rmp->startp[midx] == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1077 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1078 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
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 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
1085 * 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
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_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
1089 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1090 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1091
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1092 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
1093 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1094 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
1095 if (len > CMDBUFFSIZE - 5)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1096 len = CMDBUFFSIZE - 5;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1097 STRCPY(fields->pattern, "^\\V");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1098 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
1099 fields->pattern[len + 3] = '\\';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1100 fields->pattern[len + 4] = '$';
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1101 fields->pattern[len + 5] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1102 return QF_OK;
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
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 * 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
1107 * 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
1108 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1109 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1110 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
1111 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1112 int len;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1113
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1114 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
1115 return QF_FAIL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1116 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
1117 if (len > CMDBUFFSIZE)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1118 len = CMDBUFFSIZE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1119 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
1120 return QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1121 }
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 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1124 * 'errorformat' format pattern parser functions.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1125 * 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
1126 * 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
1127 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1128 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
1129 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1130 NULL,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1131 qf_parse_fmt_n,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1132 qf_parse_fmt_l,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1133 qf_parse_fmt_c,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1134 qf_parse_fmt_t,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1135 qf_parse_fmt_m,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1136 NULL,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1137 qf_parse_fmt_p,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1138 qf_parse_fmt_v,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1139 qf_parse_fmt_s,
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1140 qf_parse_fmt_o
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
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 * 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
1145 * "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
1146 * 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
1147 * 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
1148 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1149 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1150 qf_parse_match(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1151 char_u *linebuf,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1152 int linelen,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1153 efm_T *fmt_ptr,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1154 regmatch_T *regmatch,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1155 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1156 int qf_multiline,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1157 int qf_multiscan,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1158 char_u **tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1159 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1160 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
1161 int i;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1162 int midx;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1163 int status;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1164
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1165 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
1166 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1167 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
1168 fields->type = idx;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1169 else
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1170 fields->type = 0;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1171
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1172 // 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
1173 // 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
1174 // 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
1175 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
1176 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1177 status = QF_OK;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1178 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
1179 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
1180 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
1181 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
1182 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1183 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
1184 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
1185 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
1186 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
1187 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1188 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
1189 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
1190 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
1191 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
1192
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1193 if (status != QF_OK)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1194 return status;
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1195 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1196
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1197 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1198 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1199
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1200 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1201 * 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
1202 * '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
1203 * 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
1204 * 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
1205 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1206 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1207 qf_parse_get_fields(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1208 char_u *linebuf,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1209 int linelen,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1210 efm_T *fmt_ptr,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1211 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1212 int qf_multiline,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1213 int qf_multiscan,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1214 char_u **tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1215 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1216 regmatch_T regmatch;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1217 int status = QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1218 int r;
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 if (qf_multiscan &&
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1221 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
1222 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1223
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1224 fields->namebuf[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1225 fields->module[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1226 fields->pattern[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1227 if (!qf_multiscan)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1228 fields->errmsg[0] = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1229 fields->lnum = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1230 fields->col = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1231 fields->use_viscol = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1232 fields->enr = -1;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1233 fields->type = 0;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1234 *tail = NULL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1235
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1236 // 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
1237 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
1238 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
1239 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
1240 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
1241 if (r)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1242 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
1243 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
1244
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1245 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1246 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1247
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1248 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1249 * 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
1250 * 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
1251 * names.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1252 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1253 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1254 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
1255 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1256 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
1257 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1258 if (*fields->namebuf == NUL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1259 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1260 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
1261 return QF_FAIL;
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 qfl->qf_directory =
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1264 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
1265 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
1266 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1267 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1268 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
1269 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
1270
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1271 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1272 }
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 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1275 * 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
1276 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1277 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1278 qf_parse_file_pfx(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1279 int idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1280 qffields_T *fields,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1281 qf_list_T *qfl,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1282 char_u *tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1283 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1284 fields->valid = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1285 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
1286 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1287 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
1288 qfl->qf_currfile =
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1289 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
1290 else if (idx == 'Q')
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1291 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
1292 *fields->namebuf = NUL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1293 if (tail && *tail)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1294 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1295 STRMOVE(IObuff, skipwhite(tail));
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1296 qfl->qf_multiscan = TRUE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1297 return QF_MULTISCAN;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1298 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1299 }
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 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1302 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1303
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1304 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1305 * 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
1306 * format in 'efm').
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1307 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1308 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1309 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
1310 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1311 char_u *p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1312
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1313 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
1314 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
1315 fields->valid = FALSE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1316 if (linelen >= fields->errmsglen)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1317 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1318 // linelen + null terminator
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1319 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
1320 return QF_NOMEM;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1321 fields->errmsg = p;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1322 fields->errmsglen = linelen + 1;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1323 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1324 // 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
1325 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
1326
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1327 return QF_OK;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1328 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1329
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1330 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1331 * 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
1332 */
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1333 static int
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1334 qf_parse_multiline_pfx(
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1335 qf_info_T *qi,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1336 int qf_idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1337 int idx,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1338 qf_list_T *qfl,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1339 qffields_T *fields)
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 char_u *ptr;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1342 int len;
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 if (!qfl->qf_multiignore)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1345 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1346 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
1347
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1348 if (qfprev == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1349 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1350 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
1351 {
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1352 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
1353 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
1354 == NULL)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1355 return QF_FAIL;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1356 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
1357 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
1358 qfprev->qf_text = ptr;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1359 *(ptr += len) = '\n';
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1360 STRCPY(++ptr, fields->errmsg);
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->qf_nr == -1)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1363 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
1364 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
1365 // 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
1366 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
1367
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1368 if (!qfprev->qf_lnum)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1369 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
1370 if (!qfprev->qf_col)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1371 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
1372 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
1373 if (!qfprev->qf_fnum)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1374 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
1375 qfl->qf_directory,
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1376 *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
1377 ? fields->namebuf
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1378 : 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
1379 ? qfl->qf_currfile : 0);
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1380 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1381 if (idx == 'Z')
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1382 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
1383 line_breakcheck();
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1384
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1385 return QF_IGNORE_LINE;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1386 }
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1387
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1388 /*
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1389 * 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
1390 * Return the QF_ status.
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1391 */
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1392 static int
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1393 qf_parse_line(
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1394 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
1395 int qf_idx,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1396 char_u *linebuf,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1397 int linelen,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1398 efm_T *fmt_first,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1399 qffields_T *fields)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1400 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1401 efm_T *fmt_ptr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1402 int idx = 0;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1403 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
1404 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
1405 int status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1406
13612
89223f5d5d12 patch 8.0.1678: errorformat "%r" implies "%>"
Christian Brabandt <cb@256bit.org>
parents: 13594
diff changeset
1407 restofline:
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1408 // 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
1409 if (fmt_start == NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1410 fmt_ptr = fmt_first;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1411 else
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1412 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1413 // 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
1414 fmt_ptr = fmt_start;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1415 fmt_start = NULL;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1416 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1417
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1418 // 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
1419 // match or no match.
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1420 fields->valid = TRUE;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1421 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
1422 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1423 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
1424 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
1425 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
1426 if (status == QF_NOMEM)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1427 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1428 if (status == QF_OK)
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1429 break;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1430 }
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
1431 qfl->qf_multiscan = FALSE;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1432
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1433 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
1434 {
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1435 if (fmt_ptr != NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1436 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1437 // '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
1438 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
1439 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1440 return status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1441 }
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1442
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1443 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
1444 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1445 return status;
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1446
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1447 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
1448 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
1449 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1450 else if (fmt_ptr != NULL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1451 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1452 // honor %> item
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1453 if (fmt_ptr->conthere)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1454 fmt_start = fmt_ptr;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1455
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1456 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
1457 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1458 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
1459 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
1460 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1461 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
1462 { // 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
1463 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
1464 if (status != QF_OK)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1465 return status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1466 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1467 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
1468 { // global file names
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1469 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
1470 if (status == QF_MULTISCAN)
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1471 goto restofline;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1472 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1473 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
1474 {
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
1475 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
1476 // 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
1477 qfl->qf_multiignore = TRUE;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1478 return QF_IGNORE_LINE;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1479 }
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
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1482 return QF_OK;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1483 }
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1484
9033
0536d1469b67 commit https://github.com/vim/vim/commit/6be8c8e165204b8aa4eeb8a52be87a58d8b41b9e
Christian Brabandt <cb@256bit.org>
parents: 8932
diff changeset
1485 /*
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1486 * 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
1487 */
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1488 static int
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1489 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
1490 {
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1491 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
1492 }
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1493
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
1494 /*
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1495 * 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
1496 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1497 static int
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1498 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
1499 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1500 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
1501 return TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1502 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
1503 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1504
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1505 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1506 * 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
1507 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1508 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1509 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
1510 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1511 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
1512 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
1513 pfields->errmsglen = CMDBUFFSIZE + 1;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1514 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
1515 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
1516 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
1517 || 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
1518 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1519
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1520 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1521 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1522
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1523 /*
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1524 * 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
1525 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1526 static void
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1527 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
1528 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1529 vim_free(pfields->namebuf);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1530 vim_free(pfields->module);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1531 vim_free(pfields->errmsg);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1532 vim_free(pfields->pattern);
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
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 * 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
1537 * quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1538 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1539 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1540 qf_setup_state(
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1541 qfstate_T *pstate,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1542 char_u *enc,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1543 char_u *efile,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1544 typval_T *tv,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1545 buf_T *buf,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1546 linenr_T lnumfirst,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1547 linenr_T lnumlast)
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 #ifdef FEAT_MBYTE
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1550 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
1551 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
1552 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
1553 #endif
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1554
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1555 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
1556 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1557 EMSG2(_(e_openerrf), efile);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1558 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1559 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1560
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1561 if (tv != NULL)
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 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
1564 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
1565 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
1566 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
1567 pstate->tv = tv;
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 pstate->buf = buf;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1570 pstate->buflnum = lnumfirst;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1571 pstate->lnumlast = lnumlast;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1572
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1573 return OK;
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
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 * 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
1578 * quickfix list.
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1579 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1580 static void
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1581 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
1582 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1583 if (pstate->fd != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1584 fclose(pstate->fd);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1585
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1586 vim_free(pstate->growbuf);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1587 #ifdef FEAT_MBYTE
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1588 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
1589 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
1590 #endif
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1591 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1592
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1593 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1594 * Read the errorfile "efile" into memory, line by line, building the error
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1595 * list.
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1596 * 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
1597 * 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
1598 * 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
1599 * 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
1600 * Set the title of the list to "qf_title".
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1601 * Return -1 for error, number of errors for success.
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1602 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1603 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1604 qf_init_ext(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1605 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
1606 int qf_idx,
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1607 char_u *efile,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1608 buf_T *buf,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1609 typval_T *tv,
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1610 char_u *errorformat,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1611 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
1612 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
1613 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
1614 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
1615 char_u *enc)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1616 {
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
1617 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
1618 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
1619 qffields_T fields;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1620 qfline_T *old_last = NULL;
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1621 int adding = FALSE;
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1622 static efm_T *fmt_first = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1623 char_u *efm;
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1624 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
1625 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
1626 int status;
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1627
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1628 // 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
1629 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
1630
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
1631 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
1632 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
1633 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
1634 (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
1635 lnumfirst, lnumlast) == FAIL))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1636 goto qf_init_end;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1637
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
1638 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
1639 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1640 // make place for a new list
3965
eccae034465b updated for version 7.3.738
Bram Moolenaar <bram@vim.org>
parents: 3949
diff changeset
1641 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
1642 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
1643 }
11609
6f11697fb92c patch 8.0.0687: minor issues related to quickfix
Christian Brabandt <cb@256bit.org>
parents: 11589
diff changeset
1644 else
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
1645 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1646 // 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
1647 adding = TRUE;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
1648 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
1649 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
1650 }
7
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 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
1653
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1654 // Use the local value of 'errorformat' if it's set.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
1655 if (errorformat == p_efm && tv == NULL && *buf->b_p_efm != NUL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1656 efm = buf->b_p_efm;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1657 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1658 efm = errorformat;
9365
3830a92c12bf commit https://github.com/vim/vim/commit/688e3d1fd9b9129a5ba0e0d599ccfe6f4443daf3
Christian Brabandt <cb@256bit.org>
parents: 9334
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 // 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
1661 // previously parsed values.
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1662 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
1663 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1664 // 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
1665 VIM_CLEAR(last_efm);
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1666 free_efm_list(&fmt_first);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
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 // parse the current 'efm'
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1669 fmt_first = parse_efm_option(efm);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1670 if (fmt_first != NULL)
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1671 last_efm = vim_strsave(efm);
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
1672 }
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
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 (fmt_first == NULL) // nothing found
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1675 goto error2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1676
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1677 // 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
1678 // ":make" command, but we still want to read the errorfile then.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1679 got_int = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1680
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1681 // 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
1682 // Try to recognize one of the error formats in each line.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
1683 while (!got_int)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1684 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1685 // 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
1686 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
1687 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
1688 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
1689 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
1690 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1691
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
1692 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
1693 fmt_first, &fields);
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1694 if (status == QF_FAIL)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1695 goto error2;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1696 if (status == QF_NOMEM)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1697 goto qf_init_end;
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1698 if (status == QF_IGNORE_LINE)
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1699 continue;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1700
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
1701 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
1702 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
1703 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
1704 (*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
1705 ? 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
1706 : ((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
1707 ? 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
1708 fields.module,
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
1709 0,
9568
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1710 fields.errmsg,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1711 fields.lnum,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1712 fields.col,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1713 fields.use_viscol,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1714 fields.pattern,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1715 fields.enr,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1716 fields.type,
ccbd2e604e59 commit https://github.com/vim/vim/commit/e87e6dddc2b2a99572ec0db0833c052214c4fbd3
Christian Brabandt <cb@256bit.org>
parents: 9540
diff changeset
1717 fields.valid) == FAIL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1718 goto error2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1719 line_breakcheck();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1720 }
9531
50697f3b49d6 commit https://github.com/vim/vim/commit/e0d3797664c59afc9705808f86a7cf00fd6d874d
Christian Brabandt <cb@256bit.org>
parents: 9487
diff changeset
1721 if (state.fd == NULL || !ferror(state.fd))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1722 {
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
1723 if (qfl->qf_index == 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1724 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1725 // 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
1726 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
1727 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
1728 qfl->qf_nonevalid = TRUE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1729 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1730 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1731 {
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
1732 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
1733 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
1734 qfl->qf_ptr = qfl->qf_start;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1735 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1736 // 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
1737 retval = qfl->qf_count;
9369
ce5b79b005ec commit https://github.com/vim/vim/commit/bcf7772a23624edc0942120e564f6b4ac95604ad
Christian Brabandt <cb@256bit.org>
parents: 9365
diff changeset
1738 goto qf_init_end;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1739 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1740 EMSG(_(e_readerrf));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1741 error2:
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1742 if (!adding)
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1743 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1744 // 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
1745 qf_free(qfl);
10369
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1746 qi->qf_listcount--;
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1747 if (qi->qf_curlist > 0)
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1748 --qi->qf_curlist;
4e5b307638cb commit https://github.com/vim/vim/commit/2b946c9f9b0e0fd805fb8f3e4c16e0a68ae13129
Christian Brabandt <cb@256bit.org>
parents: 10367
diff changeset
1749 }
9369
ce5b79b005ec commit https://github.com/vim/vim/commit/bcf7772a23624edc0942120e564f6b4ac95604ad
Christian Brabandt <cb@256bit.org>
parents: 9365
diff changeset
1750 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
1751 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
1752 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
1753 qf_cleanup_state(&state);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1754 qf_free_fields(&fields);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1755
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1756 return retval;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1757 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1758
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1759 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1760 * 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
1761 * 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
1762 * 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
1763 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1764 int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1765 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
1766 char_u *efile,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1767 char_u *errorformat,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1768 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
1769 char_u *qf_title,
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1770 char_u *enc)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1771 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1772 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
1773
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1774 if (wp != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1775 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1776 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
1777 if (qi == NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1778 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1779 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1780
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1781 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
1782 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
1783 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1784
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
1785 /*
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1786 * 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
1787 * Prepends ':' to the title.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1788 */
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1789 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
1790 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
1791 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
1792 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
1793
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1794 if (title != NULL)
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1795 {
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1796 char_u *p = alloc((int)STRLEN(title) + 2);
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1797
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
1798 qfl->qf_title = p;
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1799 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
1800 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
1801 }
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1802 }
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1803
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1804 /*
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1805 * 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
1806 * 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
1807 * 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
1808 * 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
1809 */
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1810 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
1811 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
1812 {
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1813 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
1814
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
1815 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
1816 return qftitle_str;
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1817 }
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
1818
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1819 /*
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
1820 * 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
1821 * 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
1822 * the new list is added.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1823 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1824 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1825 qf_new_list(qf_info_T *qi, char_u *qf_title)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1826 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1827 int i;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1828 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1829
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1830 // 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
1831 // 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
1832 // way with ":grep'.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1833 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
1834 qf_free(&qi->qf_lists[--qi->qf_listcount]);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1835
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1836 // 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
1837 // Otherwise, add a new entry.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1838 if (qi->qf_listcount == LISTCOUNT)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1839 {
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
1840 qf_free(&qi->qf_lists[0]);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1841 for (i = 1; i < LISTCOUNT; ++i)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1842 qi->qf_lists[i - 1] = qi->qf_lists[i];
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1843 qi->qf_curlist = LISTCOUNT - 1;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1844 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1845 else
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1846 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
1847 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
1848 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
1849 qf_store_title(qfl, qf_title);
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
1850 qfl->qf_id = ++last_qf_id;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1851 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1852
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1853 /*
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1854 * 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
1855 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1856 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1857 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
1858 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1859 qf_delq_T *q;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1860
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1861 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
1862 if (q != NULL)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1863 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1864 q->qi = qi;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1865 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
1866 qf_delq_head = q;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1867 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1868 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1869
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1870 /*
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
1871 * Free a location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1872 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1873 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1874 ll_free_all(qf_info_T **pqi)
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1875 {
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1876 int i;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1877 qf_info_T *qi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1878
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1879 qi = *pqi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1880 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1881 return;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1882 *pqi = NULL; // Remove reference to this list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1883
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1884 qi->qf_refcount--;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1885 if (qi->qf_refcount < 1)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1886 {
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1887 // 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
1888 // 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
1889 // to be processed later.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1890 if (quickfix_busy > 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1891 locstack_queue_delreq(qi);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1892 else
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1893 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1894 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
1895 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
1896 vim_free(qi);
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1897 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1898 }
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1899 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1900
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1901 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
1902 * 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
1903 */
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1904 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1905 qf_free_all(win_T *wp)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1906 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1907 int i;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1908 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1909
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1910 if (wp != NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1911 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1912 // location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1913 ll_free_all(&wp->w_llist);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1914 ll_free_all(&wp->w_llist_ref);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1915 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1916 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1917 // quickfix list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1918 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
1919 qf_free(&qi->qf_lists[i]);
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
1920 }
359
6c62b9b939bd updated for version 7.0093
vimboss
parents: 297
diff changeset
1921
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1922 /*
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1923 * 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
1924 * 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
1925 * 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
1926 * 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
1927 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1928 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1929 incr_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1930 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1931 quickfix_busy++;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1932 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1933
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1934 /*
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1935 * 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
1936 */
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1937 static void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1938 decr_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1939 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1940 if (--quickfix_busy == 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1941 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1942 // 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
1943 // delete requests.
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1944 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
1945 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1946 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
1947
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1948 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
1949 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
1950 vim_free(q);
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 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1953 #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
1954 if (quickfix_busy < 0)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1955 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1956 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
1957 abort();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1958 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1959 #endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1960 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1961
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1962 #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
1963 void
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1964 check_quickfix_busy(void)
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1965 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1966 if (quickfix_busy != 0)
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 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
1969 # 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
1970 abort();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1971 # endif
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
1972 }
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 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1977 * Add an entry to the end of the list of errors.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1978 * Returns OK or FAIL.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1979 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1980 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
1981 qf_add_entry(
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1982 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
1983 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
1984 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
1985 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
1986 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
1987 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
1988 char_u *mesg, // message
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1989 long lnum, // line number
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1990 int col, // column
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1991 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
1992 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
1993 int nr, // error number
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1994 int type, // type character
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1995 int valid) // valid entry
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
1996 {
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
1997 qf_list_T *qfl = &qi->qf_lists[qf_idx];
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
1998 qfline_T *qfp;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
1999 qfline_T **lastp; // pointer to qf_last or NULL
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2000
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2001 if ((qfp = (qfline_T *)alloc((unsigned)sizeof(qfline_T))) == NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2002 return FAIL;
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
2003 if (bufnum != 0)
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2004 {
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2005 buf_T *buf = buflist_findnr(bufnum);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2006
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
2007 qfp->qf_fnum = bufnum;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2008 if (buf != NULL)
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
2009 buf->b_has_qf_entry |=
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
2010 IS_QF_STACK(qi) ? 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
2011 }
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
2012 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
2013 qfp->qf_fnum = qf_get_fnum(qi, qf_idx, dir, fname);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2014 if ((qfp->qf_text = vim_strsave(mesg)) == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2015 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2016 vim_free(qfp);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2017 return FAIL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2018 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2019 qfp->qf_lnum = lnum;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2020 qfp->qf_col = col;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
2021 qfp->qf_viscol = vis_col;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2022 if (pattern == NULL || *pattern == NUL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2023 qfp->qf_pattern = NULL;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2024 else if ((qfp->qf_pattern = vim_strsave(pattern)) == NULL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2025 {
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2026 vim_free(qfp->qf_text);
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2027 vim_free(qfp);
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2028 return FAIL;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
2029 }
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2030 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
2031 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
2032 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
2033 {
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2034 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
2035 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
2036 vim_free(qfp);
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2037 return FAIL;
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
2038 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2039 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
2040 if (type != 1 && !vim_isprintc(type)) // only printable chars allowed
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2041 type = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2042 qfp->qf_type = type;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2043 qfp->qf_valid = valid;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2044
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
2045 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
2046 if (qf_list_empty(qi, qf_idx)) // first element in the list
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2047 {
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
2048 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
2049 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
2050 qfl->qf_index = 0;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2051 qfp->qf_prev = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2052 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2053 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2054 {
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2055 qfp->qf_prev = *lastp;
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2056 (*lastp)->qf_next = qfp;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2057 }
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2058 qfp->qf_next = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2059 qfp->qf_cleared = FALSE;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2060 *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
2061 ++qfl->qf_count;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2062 if (qfl->qf_index == 0 && qfp->qf_valid) // first valid entry
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2063 {
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
2064 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
2065 qfl->qf_ptr = qfp;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2066 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2067
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2068 return OK;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2069 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2070
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2071 /*
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
2072 * Allocate a new location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2073 */
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2074 static qf_info_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2075 ll_new_list(void)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2076 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2077 qf_info_T *qi;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2078
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
2079 qi = (qf_info_T *)alloc_clear((unsigned)sizeof(qf_info_T));
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2080 if (qi != NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2081 qi->qf_refcount++;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2082 return qi;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2083 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2084
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2085 /*
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
2086 * 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
2087 * If not present, allocate a location list stack
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2088 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2089 static qf_info_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2090 ll_get_or_alloc_list(win_T *wp)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2091 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2092 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
2093 // For a location list window, use the referenced location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2094 return wp->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2095
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2096 // 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
2097 // location list.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2098 ll_free_all(&wp->w_llist_ref);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2099
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2100 if (wp->w_llist == NULL)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2101 wp->w_llist = ll_new_list(); // new location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2102 return wp->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2103 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2104
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2105 /*
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2106 * 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
2107 */
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2108 static int
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2109 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
2110 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2111 int i;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2112 qfline_T *from_qfp;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2113 qfline_T *prevp;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2114
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2115 // 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
2116 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
2117 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
2118 ++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
2119 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2120 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
2121 to_qi->qf_curlist,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2122 NULL,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2123 NULL,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2124 from_qfp->qf_module,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2125 0,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2126 from_qfp->qf_text,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2127 from_qfp->qf_lnum,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2128 from_qfp->qf_col,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2129 from_qfp->qf_viscol,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2130 from_qfp->qf_pattern,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2131 from_qfp->qf_nr,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2132 0,
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2133 from_qfp->qf_valid) == FAIL)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2134 return FAIL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2135
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2136 // 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
2137 // 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
2138 // field is copied here.
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2139 prevp = to_qfl->qf_last;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2140 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
2141 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
2142 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
2143 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
2144 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2145
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2146 return OK;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2147 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2148
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2149 /*
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2150 * 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
2151 */
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2152 static int
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2153 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
2154 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2155 // Some of the fields are populated by qf_add_entry()
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2156 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
2157 to_qfl->qf_count = 0;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2158 to_qfl->qf_index = 0;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2159 to_qfl->qf_start = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2160 to_qfl->qf_last = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2161 to_qfl->qf_ptr = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2162 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
2163 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
2164 else
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2165 to_qfl->qf_title = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2166 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
2167 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2168 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
2169 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
2170 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
2171 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2172 else
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2173 to_qfl->qf_ctx = NULL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2174
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2175 if (from_qfl->qf_count)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2176 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
2177 return FAIL;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2178
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2179 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
2180
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2181 // 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
2182 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
2183 to_qfl->qf_changedtick = 0L;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2184
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2185 // 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
2186 // 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
2187 if (to_qfl->qf_nonevalid)
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2188 {
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2189 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
2190 to_qfl->qf_index = 1;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2191 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2192
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2193 return OK;
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2194 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2195
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2196 /*
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2197 * Copy the location list stack 'from' window to 'to' window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2198 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2199 void
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2200 copy_loclist_stack(win_T *from, win_T *to)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2201 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2202 qf_info_T *qi;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2203 int idx;
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2204
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2205 // 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
2206 // 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
2207 // that window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2208 if (IS_LL_WINDOW(from))
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2209 qi = from->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2210 else
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2211 qi = from->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2212
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2213 if (qi == NULL) // no location list to copy
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2214 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2215
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2216 // allocate a new location list
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
2217 if ((to->w_llist = ll_new_list()) == NULL)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2218 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2219
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2220 to->w_llist->qf_listcount = qi->qf_listcount;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2221
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2222 // 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
2223 for (idx = 0; idx < qi->qf_listcount; ++idx)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2224 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2225 to->w_llist->qf_curlist = idx;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2226
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2227 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
2228 &to->w_llist->qf_lists[idx], to->w_llist) == FAIL)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2229 {
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2230 qf_free_all(to);
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2231 return;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2232 }
14844
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2233 }
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2234
a74786d0370c patch 8.1.0434: copy_loclist() is too long
Christian Brabandt <cb@256bit.org>
parents: 14838
diff changeset
2235 to->w_llist->qf_curlist = qi->qf_curlist; // current list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2236 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2237
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
2238 /*
10379
73e2a7abe2a3 commit https://github.com/vim/vim/commit/7618e00d3b8bfe064cfc524640d754607361f9df
Christian Brabandt <cb@256bit.org>
parents: 10369
diff changeset
2239 * 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
2240 * Also sets the b_has_qf_entry flag.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2241 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2242 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
2243 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
2244 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
2245 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
2246 char_u *ptr = NULL;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2247 buf_T *buf;
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2248 char_u *bufname;
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2249
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2250 if (fname == NULL || *fname == NUL) // no file name
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2251 return 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2252
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2253 #ifdef VMS
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2254 vms_remove_version(fname);
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2255 #endif
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2256 #ifdef BACKSLASH_IN_FILENAME
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2257 if (directory != NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2258 slash_adjust(directory);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2259 slash_adjust(fname);
2823
8bd38abda314 updated for version 7.3.187
Bram Moolenaar <bram@vim.org>
parents: 2795
diff changeset
2260 #endif
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2261 if (directory != NULL && !vim_isAbsName(fname)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2262 && (ptr = concat_fnames(directory, fname, TRUE)) != NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2263 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2264 // 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
2265 // 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
2266 // "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
2267 // directory change.
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2268 if (mch_getperm(ptr) < 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2269 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2270 vim_free(ptr);
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
2271 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
2272 if (directory)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2273 ptr = concat_fnames(directory, fname, TRUE);
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2274 else
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2275 ptr = vim_strsave(fname);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2276 }
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2277 // 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
2278 bufname = ptr;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2279 }
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2280 else
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2281 bufname = fname;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2282
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2283 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
2284 && bufref_valid(&qf_last_bufref))
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2285 {
9475
4d8f7f8da90c commit https://github.com/vim/vim/commit/b25f9a97e9aad3cbb4bc3fe87cdbd5700f8aa0c6
Christian Brabandt <cb@256bit.org>
parents: 9473
diff changeset
2286 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
2287 vim_free(ptr);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2288 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2289 else
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2290 {
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2291 vim_free(qf_last_bufname);
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2292 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
2293 if (bufname == ptr)
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2294 qf_last_bufname = bufname;
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2295 else
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2296 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
2297 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
2298 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2299 if (buf == NULL)
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
2300 return 0;
9473
bdac1019552f commit https://github.com/vim/vim/commit/8240433f48f7383c281ba2453cc55f10b8ec47d9
Christian Brabandt <cb@256bit.org>
parents: 9458
diff changeset
2301
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
2302 buf->b_has_qf_entry =
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
2303 IS_QF_STACK(qi) ? 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
2304 return buf->b_fnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2305 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2306
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2307 /*
9334
674f9e3ccd1a commit https://github.com/vim/vim/commit/38df43bd13a2498cc96b3ddd9a20dd75126bd171
Christian Brabandt <cb@256bit.org>
parents: 9201
diff changeset
2308 * 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
2309 * NULL on error.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2310 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2311 static char_u *
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
2312 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
2313 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2314 struct dir_stack_T *ds_new;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2315 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2316
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2317 // allocate new stack element and hook it in
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2318 ds_new = (struct dir_stack_T *)alloc((unsigned)sizeof(struct dir_stack_T));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2319 if (ds_new == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2320 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2321
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2322 ds_new->next = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2323 *stackptr = ds_new;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2324
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2325 // store directory on the stack
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2326 if (vim_isAbsName(dirbuf)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2327 || (*stackptr)->next == NULL
9397
e08e8b00fe48 commit https://github.com/vim/vim/commit/361c8f0e517e41f1f1d34dae328044406fde80ac
Christian Brabandt <cb@256bit.org>
parents: 9389
diff changeset
2328 || (*stackptr && is_file_stack))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2329 (*stackptr)->dirname = vim_strsave(dirbuf);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2330 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2331 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2332 // 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
2333 // 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
2334 // Let's search...
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2335 ds_new = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2336 (*stackptr)->dirname = NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2337 while (ds_new)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2338 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2339 vim_free((*stackptr)->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2340 (*stackptr)->dirname = concat_fnames(ds_new->dirname, dirbuf,
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2341 TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2342 if (mch_isdir((*stackptr)->dirname) == TRUE)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2343 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2344
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2345 ds_new = ds_new->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2346 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2347
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2348 // clean up all dirs we already left
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2349 while ((*stackptr)->next != ds_new)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2350 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2351 ds_ptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2352 (*stackptr)->next = (*stackptr)->next->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2353 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2354 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2355 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2356
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2357 // Nothing found -> it must be on top level
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2358 if (ds_new == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2359 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2360 vim_free((*stackptr)->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2361 (*stackptr)->dirname = vim_strsave(dirbuf);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2362 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2363 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2364
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2365 if ((*stackptr)->dirname != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2366 return (*stackptr)->dirname;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2367 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2368 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2369 ds_ptr = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2370 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2371 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2372 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2373 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2374 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2375
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2376 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2377 * pop dirbuf from the directory stack and return previous directory or NULL if
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2378 * stack is empty
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2379 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2380 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2381 qf_pop_dir(struct dir_stack_T **stackptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2382 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2383 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2384
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2385 // 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
2386 // 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
2387
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2388 // pop top element and free it
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2389 if (*stackptr != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2390 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2391 ds_ptr = *stackptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2392 *stackptr = (*stackptr)->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2393 vim_free(ds_ptr->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2394 vim_free(ds_ptr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2395 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2396
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2397 // return NEW top element as current dir or NULL if stack is empty
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2398 return *stackptr ? (*stackptr)->dirname : NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2399 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2400
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2401 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2402 * clean up directory stack
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2403 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2404 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
2405 qf_clean_dir_stack(struct dir_stack_T **stackptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2406 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2407 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2408
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2409 while ((ds_ptr = *stackptr) != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2410 {
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 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2416
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2417 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2418 * Check in which directory of the directory stack the given file can be
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2419 * found.
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
2420 * Returns a pointer to the directory name or NULL if not found.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2421 * Cleans up intermediate directory entries.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2422 *
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2423 * 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
2424 * If we have this directory tree:
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2425 * ./
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2426 * ./aa
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2427 * ./aa/bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2428 * ./bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2429 * ./bb/x.c
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2430 * and make says:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2431 * making all in aa
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2432 * making all in bb
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2433 * x.c:9: Error
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2434 * 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
2435 * qf_guess_filepath will return NULL.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2436 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2437 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
2438 qf_guess_filepath(qf_list_T *qfl, char_u *filename)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2439 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2440 struct dir_stack_T *ds_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2441 struct dir_stack_T *ds_tmp;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2442 char_u *fullname;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2443
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2444 // 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
2445 if (qfl->qf_dir_stack == NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2446 return NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2447
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
2448 ds_ptr = qfl->qf_dir_stack->next;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2449 fullname = NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2450 while (ds_ptr)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2451 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2452 vim_free(fullname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2453 fullname = concat_fnames(ds_ptr->dirname, filename, TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2454
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2455 // 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
2456 // is that we delete the entire stack.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2457 if ((fullname != NULL) && (mch_getperm(fullname) >= 0))
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2458 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2459
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2460 ds_ptr = ds_ptr->next;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2461 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2462
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2463 vim_free(fullname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2464
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2465 // 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
2466 while (qfl->qf_dir_stack->next != ds_ptr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2467 {
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
2468 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
2469 qfl->qf_dir_stack->next = qfl->qf_dir_stack->next->next;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2470 vim_free(ds_tmp->dirname);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2471 vim_free(ds_tmp);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2472 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2473
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
2474 return ds_ptr == NULL ? NULL : ds_ptr->dirname;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2475 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2476
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
2477 /*
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2478 * 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
2479 */
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2480 static int
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
2481 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
2482 {
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2483 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
2484 int i;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2485
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2486 if (wp != NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2487 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2488 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
2489 if (qi == NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2490 return FALSE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2491 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2492
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2493 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
2494 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
2495 return TRUE;
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2496
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2497 return FALSE;
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
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
2500 /*
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
2501 * 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
2502 * 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
2503 * 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
2504 * Similar to location list.
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2505 */
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2506 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
2507 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
2508 {
8702
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2509 qfline_T *qfp;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2510 int i;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2511
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2512 // 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
2513 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
2514 ++i, qfp = qfp->qf_next)
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
2515 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
2516 break;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2517
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2518 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
2519 return FALSE;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2520
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2521 return TRUE;
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2522 }
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2523
39d6e4f2f748 commit https://github.com/vim/vim/commit/ffec3c53496d49668669deabc0724ec78e2274fd
Christian Brabandt <cb@256bit.org>
parents: 8643
diff changeset
2524 /*
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2525 * 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
2526 * 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
2527 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2528 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2529 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
2530 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
2531 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
2532 int *qf_index,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2533 int dir)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2534 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2535 int idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2536 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
2537
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2538 idx = *qf_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2539 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
2540
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2541 do
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2542 {
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
2543 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
2544 return NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2545 ++idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2546 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
2547 } 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
2548 || (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
2549
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2550 *qf_index = idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2551 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2552 }
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 /*
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2555 * 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
2556 * 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
2557 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2558 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2559 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
2560 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
2561 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
2562 int *qf_index,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2563 int dir)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2564 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2565 int idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2566 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
2567
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2568 idx = *qf_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2569 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
2570
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2571 do
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 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
2574 return NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2575 --idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2576 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
2577 } 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
2578 || (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
2579
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2580 *qf_index = idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2581 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2582 }
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 /*
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2585 * 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
2586 * the quickfix list.
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2587 * 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
2588 * 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
2589 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2590 static qfline_T *
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2591 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
2592 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
2593 int errornr,
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2594 int dir,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2595 int *new_qfidx)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2596 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2597 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
2598 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
2599 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
2600 int prev_index;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2601 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
2602 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
2603
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2604 while (errornr--)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2605 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2606 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
2607 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
2608
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2609 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
2610 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
2611 else
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2612 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
2613 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
2614 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2615 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
2616 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
2617 if (err != NULL)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2618 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2619 EMSG(_(err));
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2620 return NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2621 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2622 break;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2623 }
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 err = NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2626 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2627
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2628 *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
2629 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2630 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2631
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2632 /*
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2633 * 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
2634 * 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
2635 */
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2636 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
2637 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
2638 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2639 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
2640 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
2641
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2642 // 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
2643 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
2644 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2645 --qf_idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2646 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
2647 }
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2648 // 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
2649 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
2650 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
2651 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2652 ++qf_idx;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2653 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
2654 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2655
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2656 *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
2657 return qf_ptr;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2658 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2659
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 * 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
2662 * 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
2663 * 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
2664 * 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
2665 * 'new_qfidx'.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2666 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2667 static qfline_T *
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2668 qf_get_entry(
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2669 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
2670 int errornr,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2671 int dir,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2672 int *new_qfidx)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2673 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2674 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
2675 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
2676
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2677 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
2678 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
2679 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
2680 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
2681
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2682 *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
2683 return qf_ptr;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2684 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2685
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2686 /*
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
2687 * 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
2688 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2689 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
2690 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
2691 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2692 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
2693
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2694 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
2695 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
2696 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
2697
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2698 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
2699 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2700
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2701 /*
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2702 * Find a help window or open one.
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 static int
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2705 jump_to_help_window(qf_info_T *qi, int *opened_window)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2706 {
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2707 win_T *wp;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2708 int flags;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2709
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2710 if (cmdmod.tab != 0)
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2711 wp = NULL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2712 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
2713 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
2714 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
2715 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
2716 else
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2717 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2718 // 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
2719 // 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
2720 flags = WSP_HELP;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2721 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
2722 && 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
2723 flags |= WSP_TOP;
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
2724 if (IS_LL_STACK(qi))
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2725 flags |= WSP_NEWLOC; // don't copy the location list
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 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
2728 return FAIL;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2729
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2730 *opened_window = TRUE;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2731
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2732 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
2733 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
2734
14560
8413e66d00a1 patch 8.1.0293: checks for type of stack is cryptic
Christian Brabandt <cb@256bit.org>
parents: 14552
diff changeset
2735 if (IS_LL_STACK(qi)) // not a quickfix list
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2736 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2737 // The new window should use the supplied location list
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2738 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
2739 qi->qf_refcount++;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2740 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2741 }
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2742
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2743 if (!p_im)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2744 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
2745
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2746 return OK;
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
2747 }
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 /*
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
2750 * 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
2751 * 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
2752 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2753 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
2754 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
2755 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2756 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
2757
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2758 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
2759 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
2760 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
2761
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2762 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
2763 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2764
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2765 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2766 * 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
2767 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2768 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
2769 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
2770 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2771 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
2772
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2773 FOR_ALL_WINDOWS(wp)
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2774 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
2775 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
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 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
2778 }
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 /*
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 * 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
2782 * 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
2783 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2784 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
2785 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
2786 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2787 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
2788 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
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 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
2791 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
2792 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2793 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
2794 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
2795 }
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 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
2798 }
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
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 * 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
2802 * 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
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 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
2805 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
2806 {
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 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
2808
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 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
2810 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
2811 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
2812 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
2813 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
2814 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
2815 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
2816 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
2817 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
2818 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2819 // 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
2820 // 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
2821 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
2822 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
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 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
2825 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2826
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2827 /*
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 * 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
2829 * 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
2830 * 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
2831 * 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
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 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
2834 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
2835 {
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 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
2837
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2838 if (win == NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2839 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2840 // Find 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
2841 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
2842 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
2843 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
2844 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
2845 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2846 // 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
2847 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
2848 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
2849 {
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2850 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
2851 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
2852 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
2853 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
2854 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2855 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
2856 } 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
2857 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2858 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2859 win_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
2860
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2861 // 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
2862 // 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
2863 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
2864 {
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2865 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
2866 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
2867 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
2868 }
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 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2870
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2871 /*
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
2872 * 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
2873 * 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
2874 * 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
2875 * 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
2876 */
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2877 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
2878 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
2879 {
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 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
2881 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
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 = 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
2884 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
2885 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
2886 {
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_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
2888 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
2889 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
2890 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
2891 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2892 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
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 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
2895 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2896 // 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
2897 // 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
2898 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
2899 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
2900 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
2901 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
2902 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
2903 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
2904 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
2905 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2906
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2907 // Remember a usable window.
14433
4a94173743d9 patch 8.1.0230: directly checking 'buftype' value
Christian Brabandt <cb@256bit.org>
parents: 14397
diff changeset
2908 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
2909 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
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
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 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
2913 }
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2914
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 /*
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2916 * 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
2917 * quickfix/location list and jump to it. If the file is already opened in a
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 * window, jump to it. Otherwise open a new window to display the file. This is
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 * called from either 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
2920 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2921 static int
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2922 qf_jump_to_usable_window(int qf_fnum, int *opened_window)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2923 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2924 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
2925 int usable_win;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2926 qf_info_T *ll_ref;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2927 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
2928
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2929 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
2930
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2931 ll_ref = curwin->w_llist_ref;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2932 if (ll_ref != NULL)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2933 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2934 // Find a non-quickfix window with this location list
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2935 usable_win_ptr = qf_find_win_with_loclist(ll_ref);
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2936 if (usable_win_ptr != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2937 usable_win = 1;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2938 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2939
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2940 if (!usable_win)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2941 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2942 // Locate a window showing a normal buffer
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2943 win = qf_find_win_with_normal_buf();
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2944 if (win != NULL)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2945 usable_win = 1;
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2946 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2947
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2948 // If no usable window is found and 'switchbuf' contains "usetab"
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2949 // then search in other tabs.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2950 if (!usable_win && (swb_flags & SWB_USETAB))
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2951 usable_win = qf_goto_tabwin_with_file(qf_fnum);
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2952
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2953 // If there is only one window and it is the quickfix window, create a
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2954 // new one above the quickfix window.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2955 if ((ONE_WINDOW && bt_quickfix(curbuf)) || !usable_win)
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2956 {
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2957 if (qf_open_new_file_win(ll_ref) != OK)
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2958 return FAIL;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2959 *opened_window = TRUE; // close it when fail
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2960 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2961 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2962 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2963 if (curwin->w_llist_ref != NULL) // In a location window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2964 qf_goto_win_with_ll_file(usable_win_ptr, qf_fnum, ll_ref);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2965 else // In a quickfix window
13882
f48fcaa196a9 patch 8.0.1812: the qf_jump_to_usable_window() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13868
diff changeset
2966 qf_goto_win_with_qfl_file(qf_fnum);
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2967 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2968
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2969 return OK;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2970 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2971
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2972 /*
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2973 * Edit the selected file or help file.
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2974 * Returns OK if successfully edited the file, FAIL on failing to open the
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2975 * buffer and NOTDONE if the quickfix/location list was freed by an autocmd
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2976 * when opening the buffer.
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2977 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2978 static int
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2979 qf_jump_edit_buffer(
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2980 qf_info_T *qi,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2981 qfline_T *qf_ptr,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2982 int forceit,
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2983 win_T *oldwin,
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
2984 int *opened_window)
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2985 {
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
2986 qf_list_T *qfl = &qi->qf_lists[qi->qf_curlist];
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2987 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
2988 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
2989 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
2990
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2991 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
2992 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
2993 // 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
2994 // 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
2995 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
2996 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
2997 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
2998 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
2999 }
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3000
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3001 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
3002 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
3003 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
3004 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3005 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3006 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
3007 (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
3008
14956
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3009 // 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
3010 // present.
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3011 if (IS_LL_STACK(qi) && !win_valid_any_tab(oldwin))
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3012 {
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3013 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
3014 *opened_window = FALSE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3015 return NOTDONE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3016 }
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3017
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3018 if (IS_QF_STACK(qi) && !qflist_valid(NULL, save_qfid))
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3019 {
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3020 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
3021 return NOTDONE;
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3022 }
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3023
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3024 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
3025 || !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
3026 {
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3027 if (IS_QF_STACK(qi))
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3028 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
3029 else
940def6df43f patch 8.1.0489: crash when autocmd clears vimpgrep location list
Bram Moolenaar <Bram@vim.org>
parents: 14954
diff changeset
3030 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
3031 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
3032 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3033
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3034 return retval;
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
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3037 /*
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
3038 * 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
3039 * 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
3040 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3041 static void
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3042 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
3043 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
3044 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
3045 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
3046 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
3047 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3048 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
3049 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
3050 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
3051 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
3052
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3053 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
3054 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3055 // 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
3056 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
3057 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
3058 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3059 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
3060 i = curbuf->b_ml.ml_line_count;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3061 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
3062 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3063 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
3064 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3065 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
3066 #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
3067 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
3068 #endif
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3069 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
3070 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3071 // 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
3072 // 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
3073 // 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
3074 // 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
3075 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
3076 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
3077 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
3078 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3079 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
3080 break;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3081 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
3082 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3083 curwin->w_cursor.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
3084 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
3085 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3086 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3087 ++screen_col;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3088 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3089 }
14552
b298737a7188 patch 8.1.0289: cursor moves to wrong column after quickfix jump
Christian Brabandt <cb@256bit.org>
parents: 14550
diff changeset
3090 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
3091 check_cursor();
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3092 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3093 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3094 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
3095 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3096 else
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3097 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3098 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
3099
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3100 // 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
3101 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
3102 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
3103 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
3104 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
3105 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
3106 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3107 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3108
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3109 /*
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3110 * 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
3111 */
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3112 static void
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3113 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
3114 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
3115 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
3116 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
3117 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
3118 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
3119 {
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3120 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
3121 int len;
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3122
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3123 // 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
3124 // 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
3125 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
3126 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
3127 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
3128 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
3129 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
3130 (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
3131 // 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
3132 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
3133 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
3134
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3135 // 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
3136 // 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
3137 // 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
3138 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
3139 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
3140 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
3141 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
3142 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
3143 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
3144 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
3145 }
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3146
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3147 /*
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3148 * Find a usable window for opening a file from the quickfix/location list. If
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3149 * a window is not found then open a new window.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3150 * 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
3151 * 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
3152 * with the entry.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3153 */
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3154 static int
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3155 qf_jump_open_window(qf_info_T *qi, qfline_T *qf_ptr, int *opened_window)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3156 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3157 // 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
3158 if (qf_ptr->qf_type == 1 && (!bt_help(curwin->w_buffer) || cmdmod.tab != 0))
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3159 if (jump_to_help_window(qi, opened_window) == FAIL)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3160 return FAIL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3161
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3162 // 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
3163 // file in.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3164 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
3165 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3166 // 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
3167 // 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
3168 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
3169 return NOTDONE;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3170
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3171 if (qf_jump_to_usable_window(qf_ptr->qf_fnum, opened_window) == FAIL)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3172 return FAIL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3173 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3174
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3175 return OK;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3176 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3177
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3178 /*
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3179 * 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
3180 * 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
3181 * jump.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3182 * 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
3183 * 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
3184 * the file.
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
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3187 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
3188 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
3189 int qf_index,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3190 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
3191 int forceit,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3192 win_T *oldwin,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3193 int *opened_window,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3194 int openfold,
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3195 int print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3196 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3197 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
3198 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
3199 int retval = OK;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3200
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3201 // 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
3202 // autowrite etc.
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3203 old_curbuf = curbuf;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3204 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
3205
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3206 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
3207 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3208 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
3209 opened_window);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3210 if (retval != OK)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3211 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3212 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3213
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3214 // 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
3215 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
3216 setpcmark();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3217
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3218 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
3219 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
3220
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3221 #ifdef FEAT_FOLDING
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3222 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
3223 foldOpenCursor();
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3224 #endif
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3225 if (print_message)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3226 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
3227
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3228 return retval;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3229 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3230
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3231 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3232 * jump to a quickfix line
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3233 * if dir == FORWARD go "errornr" valid entries forward
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3234 * if dir == BACKWARD go "errornr" valid entries backward
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3235 * if dir == FORWARD_FILE go "errornr" valid entries files backward
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3236 * if dir == BACKWARD_FILE go "errornr" valid entries files backward
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3237 * else if "errornr" is zero, redisplay the same line
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3238 * else go to entry "errornr"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3239 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3240 void
12449
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3241 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
3242 int dir,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3243 int errornr,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3244 int forceit)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3245 {
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
3246 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3247 qfline_T *qf_ptr;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3248 qfline_T *old_qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3249 int qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3250 int old_qf_index;
639
c79d4df4686e updated for version 7.0185
vimboss
parents: 634
diff changeset
3251 char_u *old_swb = p_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3252 unsigned old_swb_flags = swb_flags;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3253 int opened_window = FALSE;
1743
734d5bdae499 updated for version 7.2-041
vimboss
parents: 1683
diff changeset
3254 win_T *oldwin = curwin;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3255 int print_message = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3256 #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
3257 int old_KeyTyped = KeyTyped; // getting file may reset it
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3258 #endif
12503
4d40b2644e92 patch 8.0.1130: the qf_jump() function is still too long
Christian Brabandt <cb@256bit.org>
parents: 12477
diff changeset
3259 int retval = OK;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3260
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3261 if (qi == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
3262 qi = &ql_info;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3263
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3264 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3265 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3266 EMSG(_(e_quickfix));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3267 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3268 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3269
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
3270 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
3271
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3272 qf_ptr = qfl->qf_ptr;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3273 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
3274 qf_index = qfl->qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3275 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
3276
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3277 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
3278 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
3279 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3280 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
3281 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
3282 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3283 }
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
3284
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3285 qfl->qf_index = qf_index;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3286 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
3287 // 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
3288 // window
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3289 print_message = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3290
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3291 retval = qf_jump_open_window(qi, qf_ptr, &opened_window);
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3292 if (retval == FAIL)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3293 goto failed;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3294 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3295 goto theend;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3296
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3297 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
3298 &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
3299 if (retval == NOTDONE)
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3300 {
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3301 // 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
3302 qi = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3303 qf_ptr = NULL;
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3304 }
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3305
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3306 if (retval != OK)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3307 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3308 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
3309 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
3310 if (qf_ptr != NULL && qf_ptr->qf_fnum != 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3311 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3312 // 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
3313 // happen if the file was readonly and we changed something.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3314 failed:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3315 qf_ptr = old_qf_ptr;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3316 qf_index = old_qf_index;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3317 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3318 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3319 theend:
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3320 if (qi != NULL)
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
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->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
3323 qfl->qf_index = qf_index;
8605
536b9b88d1ca commit https://github.com/vim/vim/commit/0899d698030ec076eb26352cda1ea334ab0819d9
Christian Brabandt <cb@256bit.org>
parents: 8603
diff changeset
3324 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3325 if (p_swb != old_swb && opened_window)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3326 {
14838
6040d93396de patch 8.1.0431: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14796
diff changeset
3327 // 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
3328 // modeline has changed the value.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3329 if (p_swb == empty_option)
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3330 {
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3331 p_swb = old_swb;
1621
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3332 swb_flags = old_swb_flags;
82b5078be2dd updated for version 7.2a
vimboss
parents: 1571
diff changeset
3333 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3334 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3335 free_string_option(old_swb);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3336 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3337 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3338
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3339 // 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
3340 static int qfFileAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3341 static int qfSepAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3342 static int qfLineAttr;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3343
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3344 /*
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3345 * 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
3346 * 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
3347 * '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
3348 * quickfix list.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3349 */
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3350 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
3351 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
3352 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3353 char_u *fname;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3354 buf_T *buf;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3355 int filter_entry;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3356
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3357 fname = NULL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3358 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
3359 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
3360 (char *)qfp->qf_module);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3361 else {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3362 if (qfp->qf_fnum != 0
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3363 && (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
3364 {
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3365 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
3366 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
3367 fname = gettail(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3368 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3369 if (fname == NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3370 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
3371 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3372 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
3373 qf_idx, (char *)fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3374 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3375
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3376 // 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
3377 // 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
3378 // text of the entry.
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3379 filter_entry = TRUE;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3380 if (qfp->qf_module != NULL && *qfp->qf_module != NUL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3381 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
3382 if (filter_entry && fname != NULL)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3383 filter_entry &= message_filtered(fname);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3384 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
3385 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
3386 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3387 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
3388 if (filter_entry)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3389 return;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3390
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3391 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
3392 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
3393
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3394 if (qfp->qf_lnum != 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3395 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
3396 if (qfp->qf_lnum == 0)
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3397 IObuff[0] = NUL;
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3398 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
3399 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
3400 else
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3401 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
3402 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
3403 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
3404 (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
3405 msg_puts_attr(IObuff, qfLineAttr);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3406 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
3407 if (qfp->qf_pattern != NULL)
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 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
3410 msg_puts(IObuff);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3411 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
3412 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3413 msg_puts((char_u *)" ");
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3414
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3415 // 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
3416 // 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
3417 // with ^^^^.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3418 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
3419 ? 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
3420 IObuff, IOSIZE);
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3421 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
3422 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
3423 }
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3424
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
3425 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3426 * ":clist": list all errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3427 * ":llist": list all locations
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3428 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3429 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3430 qf_list(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3431 {
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
3432 qf_list_T *qfl;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3433 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3434 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3435 int idx1 = 1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3436 int idx2 = -1;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3437 char_u *arg = eap->arg;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3438 int plus = FALSE;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3439 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
3440 // recognised errors
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3441 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3442
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3443 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3444 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3445 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3446 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3447 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3448 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3449 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3450 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3451 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3452
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3453 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3454 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3455 EMSG(_(e_quickfix));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3456 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3457 }
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3458 if (*arg == '+')
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3459 {
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3460 ++arg;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3461 plus = TRUE;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3462 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3463 if (!get_list_range(&arg, &idx1, &idx2) || *arg != NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3464 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3465 EMSG(_(e_trailing));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3466 return;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3467 }
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
3468 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
3469 if (plus)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3470 {
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
3471 i = qfl->qf_index;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3472 idx2 = i + idx1;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3473 idx1 = i;
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3474 }
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3475 else
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3476 {
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
3477 i = qfl->qf_count;
9379
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3478 if (idx1 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3479 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
3480 if (idx2 < 0)
b398e4e12751 commit https://github.com/vim/vim/commit/e8fea0728a2fa1fe78ef0ac90dee1a84bd7ef9fb
Christian Brabandt <cb@256bit.org>
parents: 9369
diff changeset
3481 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
3482 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3483
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3484 // 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
3485 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
3486
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3487 // 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
3488 // 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
3489 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
3490 if (qfFileAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3491 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
3492 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
3493 if (qfSepAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3494 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
3495 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
3496 if (qfLineAttr == 0)
888441e8fbb0 patch 8.0.1332: highlighting in quickfix window could be better
Christian Brabandt <cb@256bit.org>
parents: 12531
diff changeset
3497 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
3498
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3499 if (qfl->qf_nonevalid)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3500 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
3501 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
3502 for (i = 1; !got_int && i <= qfl->qf_count; )
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3503 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3504 if ((qfp->qf_valid || all) && idx1 <= i && i <= idx2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3505 {
2047
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3506 if (got_int)
85da03763130 updated for version 7.2.333
Bram Moolenaar <bram@zimbu.org>
parents: 1918
diff changeset
3507 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3508
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
3509 qf_list_entry(qfp, i, i == qfl->qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3510 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3511
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3512 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3513 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3514 break;
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
3515 ++i;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3516 ui_breakcheck();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3517 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3518 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3519
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3520 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3521 * Remove newlines and leading whitespace from an error message.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3522 * Put the result in "buf[bufsize]".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3523 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3524 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3525 qf_fmt_text(char_u *text, char_u *buf, int bufsize)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3526 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3527 int i;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3528 char_u *p = text;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3529
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3530 for (i = 0; *p != NUL && i < bufsize - 1; ++i)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3531 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3532 if (*p == '\n')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3533 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3534 buf[i] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3535 while (*++p != NUL)
11129
f4ea50924c6d patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents: 11063
diff changeset
3536 if (!VIM_ISWHITE(*p) && *p != '\n')
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3537 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3538 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3539 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3540 buf[i] = *p++;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3541 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3542 buf[i] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3543 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3544
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3545 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3546 * 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
3547 * quickfix/location list.
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3548 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3549 static void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3550 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
3551 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3552 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
3553 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
3554 char_u buf[IOSIZE];
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3555
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3556 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
3557 lead,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3558 which + 1,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3559 qi->qf_listcount,
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3560 count);
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3561
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3562 if (title != NULL)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3563 {
9579
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3564 size_t len = STRLEN(buf);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3565
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3566 if (len < 34)
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3567 {
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3568 vim_memset(buf + len, ' ', 34 - len);
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3569 buf[34] = NUL;
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3570 }
2fb7e008ac9b commit https://github.com/vim/vim/commit/16ec3c9be3fcdc38530bddb12978bc5a7b98c0f6
Christian Brabandt <cb@256bit.org>
parents: 9573
diff changeset
3571 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
3572 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3573 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
3574 msg(buf);
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3575 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3576
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3577 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3578 * ":colder [count]": Up in the quickfix stack.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3579 * ":cnewer [count]": Down in the quickfix stack.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3580 * ":lolder [count]": Up in the location list stack.
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3581 * ":lnewer [count]": Down in the location list stack.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3582 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3583 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3584 qf_age(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3585 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3586 qf_info_T *qi = &ql_info;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3587 int count;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3588
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3589 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3590 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3591 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3592 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3593 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3594 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3595 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3596 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3597 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3598
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3599 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3600 count = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3601 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3602 count = 1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3603 while (count--)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3604 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3605 if (eap->cmdidx == CMD_colder || eap->cmdidx == CMD_lolder)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3606 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3607 if (qi->qf_curlist == 0)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3608 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3609 EMSG(_("E380: At bottom of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3610 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3611 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3612 --qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3613 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3614 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3615 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3616 if (qi->qf_curlist >= qi->qf_listcount - 1)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3617 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3618 EMSG(_("E381: At top of quickfix stack"));
4371
000bb500208d updated for version 7.3.934
Bram Moolenaar <bram@vim.org>
parents: 4352
diff changeset
3619 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3620 }
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3621 ++qi->qf_curlist;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3622 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3623 }
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3624 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
3625 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3626 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3627
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3628 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
3629 * 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
3630 */
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3631 void
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3632 qf_history(exarg_T *eap)
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3633 {
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3634 qf_info_T *qi = &ql_info;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3635 int i;
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3636
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3637 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
3638 qi = GET_LOC_LIST(curwin);
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
3639 if (qf_stack_empty(qi) || qf_list_empty(qi, qi->qf_curlist))
9538
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3640 MSG(_("No entries"));
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3641 else
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3642 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
3643 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
3644 }
26da1efa9e46 commit https://github.com/vim/vim/commit/f6acffbe83e622542d9fdf3066f51933e46e4954
Christian Brabandt <cb@256bit.org>
parents: 9534
diff changeset
3645
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3646 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3647 * 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
3648 * associated with the list like context and title are not freed.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3649 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3650 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
3651 qf_free_items(qf_list_T *qfl)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3652 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3653 qfline_T *qfp;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3654 qfline_T *qfpnext;
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3655 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
3656
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
3657 while (qfl->qf_count && qfl->qf_start != NULL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3658 {
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
3659 qfp = qfl->qf_start;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3660 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
3661 if (!stop)
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3662 {
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
3663 vim_free(qfp->qf_module);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3664 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
3665 vim_free(qfp->qf_pattern);
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3666 stop = (qfp == qfpnext);
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
3667 vim_free(qfp);
3982
4934eb2e22dc updated for version 7.3.746
Bram Moolenaar <bram@vim.org>
parents: 3974
diff changeset
3668 if (stop)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3669 // 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
3670 // 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
3671 // 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
3672 qfl->qf_count = 1;
3949
37a4cacd2051 updated for version 7.3.730
Bram Moolenaar <bram@vim.org>
parents: 3939
diff changeset
3673 }
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
3674 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
3675 --qfl->qf_count;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3676 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3677
11700
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3678 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
3679 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
3680 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
3681 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
3682 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
3683
dd821396754e patch 8.0.0733: can only add entries to one list in the quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11609
diff changeset
3684 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
3685 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
3686 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
3687 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
3688 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
3689 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
3690 qfl->qf_multiscan = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3691 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3692
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3693 /*
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3694 * 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
3695 * 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
3696 */
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3697 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
3698 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
3699 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3700 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
3701
13244
ac42c4b11dbc patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents: 13115
diff changeset
3702 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
3703 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
3704 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
3705 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
3706 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
3707 }
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3708
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
3709 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3710 * qf_mark_adjust: adjust marks
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3711 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3712 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3713 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
3714 win_T *wp,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3715 linenr_T line1,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3716 linenr_T line2,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3717 long amount,
7a743053dfd6 patch 8.0.1104: the qf_jump() function is too long
Christian Brabandt <cb@256bit.org>
parents: 12427
diff changeset
3718 long amount_after)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3719 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3720 int i;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3721 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
3722 int idx;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3723 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
3724 int found_one = FALSE;
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3725 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
3726
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3727 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
3728 return;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3729 if (wp != NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3730 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3731 if (wp->w_llist == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3732 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3733 qi = wp->w_llist;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3734 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3735
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3736 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
3737 if (!qf_list_empty(qi, idx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3738 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
3739 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
3740 ++i, qfp = qfp->qf_next)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3741 if (qfp->qf_fnum == curbuf->b_fnum)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3742 {
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3743 found_one = TRUE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3744 if (qfp->qf_lnum >= line1 && qfp->qf_lnum <= line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3745 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3746 if (amount == MAXLNUM)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3747 qfp->qf_cleared = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3748 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3749 qfp->qf_lnum += amount;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3750 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3751 else if (amount_after && qfp->qf_lnum > line2)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3752 qfp->qf_lnum += amount_after;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3753 }
9201
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3754
692e156c7023 commit https://github.com/vim/vim/commit/2f095a4bc4d786e0ac834f48dd18a94fe2d140e3
Christian Brabandt <cb@256bit.org>
parents: 9197
diff changeset
3755 if (!found_one)
9608
fa64afb99dda commit https://github.com/vim/vim/commit/c1542744e788d96fed24dd421f43009288092504
Christian Brabandt <cb@256bit.org>
parents: 9579
diff changeset
3756 curbuf->b_has_qf_entry &= ~buf_has_flag;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3757 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3758
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3759 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3760 * Make a nice message out of the error character and the error number:
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3761 * char number message
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3762 * e or E 0 " error"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3763 * w or W 0 " warning"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3764 * i or I 0 " info"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3765 * 0 0 ""
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3766 * other 0 " c"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3767 * e or E n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3768 * w or W n " warning n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3769 * i or I n " info n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3770 * 0 n " error n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3771 * other n " c n"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3772 * 1 x "" :helpgrep
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3773 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3774 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3775 qf_types(int c, int nr)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3776 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3777 static char_u buf[20];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3778 static char_u cc[3];
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3779 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3780
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3781 if (c == 'W' || c == 'w')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3782 p = (char_u *)" warning";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3783 else if (c == 'I' || c == 'i')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3784 p = (char_u *)" info";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3785 else if (c == 'E' || c == 'e' || (c == 0 && nr > 0))
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3786 p = (char_u *)" error";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3787 else if (c == 0 || c == 1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3788 p = (char_u *)"";
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3789 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3790 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3791 cc[0] = ' ';
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3792 cc[1] = c;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3793 cc[2] = NUL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3794 p = cc;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3795 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3796
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3797 if (nr <= 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3798 return p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3799
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3800 sprintf((char *)buf, "%s %3d", (char *)p, nr);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3801 return buf;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3802 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3803
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3804 /*
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
3805 * 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
3806 * 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
3807 */
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3808 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
3809 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
3810 {
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3811 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
3812
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3813 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
3814 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
3815
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3816 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
3817 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
3818
14491
9df0fcbfebb2 patch 8.1.0259: no test for fixed quickfix issue
Christian Brabandt <cb@256bit.org>
parents: 14477
diff changeset
3819 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
3820 {
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3821 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
3822 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
3823 }
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3824
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3825 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
3826 {
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3827 char_u cmd[32];
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3828
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3829 vim_snprintf((char *)cmd, sizeof(cmd), "split +%ld%s",
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3830 (long)curwin->w_cursor.lnum,
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3831 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
3832 if (do_cmdline_cmd(cmd) == OK)
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3833 do_cmdline_cmd((char_u *) "clearjumps");
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3834 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
3835 }
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3836
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3837 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
3838 }
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3839
19d99d9e670c patch 8.1.0213: CTRL-W CR does not work properly in a quickfix window
Christian Brabandt <cb@256bit.org>
parents: 14307
diff changeset
3840 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3841 * ":cwindow": open the quickfix window if we have errors to display,
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3842 * close it if not.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3843 * ":lwindow": open the location list window if we have locations to display,
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3844 * close it if not.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3845 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3846 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3847 ex_cwindow(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3848 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3849 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
3850 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3851 win_T *win;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3852
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3853 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3854 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3855 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3856 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3857 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3858 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3859
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
3860 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
3861
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3862 // Look for an existing quickfix window.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3863 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3864
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3865 // 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
3866 // 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
3867 // 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
3868 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
3869 || 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
3870 || qf_list_empty(qi, qi->qf_curlist))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3871 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3872 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3873 ex_cclose(eap);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3874 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3875 else if (win == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3876 ex_copen(eap);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3877 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3878
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3879 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3880 * ":cclose": close the window showing the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3881 * ":lclose": close the window showing the location list
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3882 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3883 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
3884 ex_cclose(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3885 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3886 win_T *win = NULL;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3887 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3888
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
3889 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3890 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3891 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3892 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3893 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3894 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3895
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
3896 // Find existing quickfix window and close it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
3897 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3898 if (win != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3899 win_close(win, FALSE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3900 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3901
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
3902 /*
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
3903 * 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
3904 */
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3905 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
3906 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
3907 {
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3908 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
3909 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
3910 }
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3911
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
3912 /*
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3913 * 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
3914 * 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
3915 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3916 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3917 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
3918 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3919 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3920
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3921 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
3922 if (win == NULL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3923 return FAIL;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3924
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3925 win_goto(win);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3926 if (resize)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3927 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3928 if (vertsplit)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3929 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3930 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
3931 win_setwidth(sz);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3932 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3933 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
3934 win_setheight(sz);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3935 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3936
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3937 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3938 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3939
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3940 /*
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3941 * 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
3942 * 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
3943 * 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
3944 */
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3945 static int
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3946 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
3947 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3948 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
3949 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
3950 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
3951 int flags = 0;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3952 win_T *win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3953
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3954 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
3955
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3956 // 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
3957 win = curwin;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3958
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3959 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
3960 // 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
3961 // :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
3962 win_goto(lastwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3963 // 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
3964 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
3965 flags = WSP_BELOW;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3966 flags |= WSP_NEWLOC;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3967 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
3968 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
3969 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3970
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3971 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
3972 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3973 // 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
3974 // 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
3975 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
3976 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
3977 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3978
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3979 if (oldwin != curwin)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3980 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
3981 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
3982 {
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3983 // 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
3984 (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
3985 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
3986 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3987 else
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 // 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
3990 (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
3991
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3992 // switch off 'swapfile'
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3993 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
3994 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
3995 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3996 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
3997 RESET_BINDING(curwin);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3998 #ifdef FEAT_DIFF
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
3999 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
4000 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4001 #ifdef FEAT_FOLDING
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4002 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
4003 OPT_LOCAL);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4004 #endif
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4005 }
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 // 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
4008 // 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
4009 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
4010 win_setheight(height);
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4011 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
4012 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
4013 prevwin = win;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4014
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4015 return OK;
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4016 }
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4017
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4018 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4019 * ":copen": open a window that shows the list of errors.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4020 * ":lopen": open a window that shows the location list.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4021 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4022 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4023 ex_copen(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4024 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4025 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
4026 qf_list_T *qfl;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4027 int height;
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4028 int status = FAIL;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4029 int lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4030
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4031 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4032 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4033 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4034 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4035 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4036 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4037 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4038 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4039 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4040
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4041 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4042
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4043 if (eap->addr_count != 0)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4044 height = eap->line2;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4045 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4046 height = QF_WINHEIGHT;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4047
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4048 reset_VIsual_and_resel(); // stop Visual mode
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4049 #ifdef FEAT_GUI
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4050 need_mouse_correct = TRUE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4051 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4052
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4053 // 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
4054 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
4055 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
4056 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
4057 if (status == FAIL)
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4058 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
4059 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4060 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
4061 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4062 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4063
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4064 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
4065 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
4066 // 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
4067 // the quickfix list
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4068 lnum = qfl->qf_index;
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4069
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4070 // 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
4071 qf_fill_buffer(qi, curbuf, NULL);
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4072
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4073 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4074
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4075 curwin->w_cursor.lnum = lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4076 curwin->w_cursor.col = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4077 check_cursor();
14796
74fd69162d50 patch 8.1.0410: the ex_copen() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14790
diff changeset
4078 update_topline(); // scroll to show the line
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4079 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4080
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4081 /*
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4082 * 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
4083 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4084 static void
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4085 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
4086 {
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4087 win_T *old_curwin = curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4088
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4089 curwin = win;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4090 curbuf = win->w_buffer;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4091 curwin->w_cursor.lnum = lnum;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4092 curwin->w_cursor.col = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4093 #ifdef FEAT_VIRTUALEDIT
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4094 curwin->w_cursor.coladd = 0;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4095 #endif
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4096 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
4097 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
4098 redraw_later(VALID);
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4099 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
4100 curwin = old_curwin;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4101 curbuf = curwin->w_buffer;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4102 }
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4103
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4104 /*
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4105 * :cbottom/:lbottom commands.
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4106 */
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4107 void
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4108 ex_cbottom(exarg_T *eap)
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4109 {
9458
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4110 qf_info_T *qi = &ql_info;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4111 win_T *win;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4112
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4113 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
4114 {
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4115 qi = GET_LOC_LIST(curwin);
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4116 if (qi == NULL)
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4117 {
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4118 EMSG(_(e_loclist));
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4119 return;
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4120 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4121 }
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4122
374afcf9d11d commit https://github.com/vim/vim/commit/537ef08408c50e0c4104d57f74993b3b0ed9560d
Christian Brabandt <cb@256bit.org>
parents: 9432
diff changeset
4123 win = qf_find_win(qi);
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4124 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
4125 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
4126 }
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4127
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4128 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4129 * Return the number of the current entry (line number in the quickfix
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4130 * window).
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4131 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4132 linenr_T
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4133 qf_current_entry(win_T *wp)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4134 {
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4135 qf_info_T *qi = &ql_info;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4136
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4137 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
4138 // In the location list window, use the referenced location list
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4139 qi = wp->w_llist_ref;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4140
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4141 return qi->qf_lists[qi->qf_curlist].qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4142 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4143
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4144 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4145 * Update the cursor position in the quickfix window to the current error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4146 * Return TRUE if there is a quickfix window.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4147 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4148 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4149 qf_win_pos_update(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4150 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
4151 int old_qf_index) // previous qf_index or zero
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4152 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4153 win_T *win;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4154 int qf_index = qi->qf_lists[qi->qf_curlist].qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4155
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4156 // 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
4157 // it's viewable.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4158 win = qf_find_win(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4159 if (win != NULL
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4160 && qf_index <= win->w_buffer->b_ml.ml_line_count
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4161 && old_qf_index != qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4162 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4163 if (qf_index > old_qf_index)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4164 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4165 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
4166 win->w_redraw_bot = qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4167 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4168 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4169 {
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4170 win->w_redraw_top = qf_index;
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4171 win->w_redraw_bot = old_qf_index;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4172 }
9432
abb72f0b9e06 commit https://github.com/vim/vim/commit/dcb170018642ec144cd87d9d9fe076575b8d1263
Christian Brabandt <cb@256bit.org>
parents: 9397
diff changeset
4173 qf_win_goto(win, qf_index);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4174 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4175 return win != NULL;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4176 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4177
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4178 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4179 * 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
4180 * stack.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4181 */
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4182 static int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4183 is_qf_win(win_T *win, qf_info_T *qi)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4184 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4185 // 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
4186 // set to NULL.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4187 // 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
4188 // pointing to the location list.
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4189 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
4190 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
4191 || (IS_LL_STACK(qi) && win->w_llist_ref == qi))
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4192 return TRUE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4193
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4194 return FALSE;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4195 }
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4196
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4197 /*
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
4198 * 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
4199 * Only searches in the current tabpage.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4200 */
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4201 static win_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4202 qf_find_win(qf_info_T *qi)
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4203 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4204 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4205
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4206 FOR_ALL_WINDOWS(win)
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4207 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
4208 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
4209 return NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4210 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4211
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4212 /*
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4213 * Find a quickfix buffer.
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4214 * Searches in windows opened in all the tabs.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4215 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4216 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4217 qf_find_buf(qf_info_T *qi)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4218 {
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4219 tabpage_T *tp;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4220 win_T *win;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4221
859
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4222 FOR_ALL_TAB_WINDOWS(tp, win)
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4223 if (is_qf_win(win, qi))
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4224 return win->w_buffer;
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4225
99305c4c42d4 updated for version 7.0g02
vimboss
parents: 857
diff changeset
4226 return NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4227 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4228
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4229 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4230 * 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
4231 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4232 static void
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4233 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
4234 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4235 win_T *win;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4236 win_T *curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4237
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4238 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
4239 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4240 curwin_save = curwin;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4241 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
4242 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
4243 curwin = curwin_save;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4244 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4245 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4246
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4247 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4248 * Find the quickfix buffer. If it exists, update the contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4249 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4250 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4251 qf_update_buffer(qf_info_T *qi, qfline_T *old_last)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4252 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4253 buf_T *buf;
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4254 win_T *win;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4255 aco_save_T aco;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4256
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4257 // Check if a buffer for the quickfix list exists. Update it.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4258 buf = qf_find_buf(qi);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4259 if (buf != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4260 {
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4261 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
4262
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4263 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
4264 // 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
4265 aucmd_prepbuf(&aco, buf);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4266
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
4267 qf_update_win_titlevar(qi);
3016
58bba69b3371 updated for version 7.3.280
Bram Moolenaar <bram@vim.org>
parents: 3002
diff changeset
4268
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4269 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
4270 ++CHANGEDTICK(buf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4271
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4272 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4273 {
8932
25c2031e9f9f commit https://github.com/vim/vim/commit/c1808d5822ed9534ef7f0fe509b15bee92a5cc28
Christian Brabandt <cb@256bit.org>
parents: 8751
diff changeset
4274 (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
4275
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4276 // 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
4277 aucmd_restbuf(&aco);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4278 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4279
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4280 // 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
4281 // 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
4282 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
4283 redraw_buf_later(buf, NOT_VALID);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4284 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4285 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4286
6793
e1d59836eecc patch 7.4.718
Bram Moolenaar <bram@vim.org>
parents: 6721
diff changeset
4287 /*
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4288 * 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
4289 */
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4290 static int
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4291 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
4292 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4293 int len;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4294 buf_T *errbuf;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4295
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4296 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
4297 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4298 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
4299 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4300 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4301 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
4302 && (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
4303 && errbuf->b_fname != NULL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
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 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
4306 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
4307 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4308 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4309 // 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
4310 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
4311 || 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
4312 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4313 if (*dirname == NUL)
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4314 mch_dirname(dirname, MAXPATHL);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4315 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
4316 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4317 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
4318 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4319 len = (int)STRLEN(IObuff);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4320 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4321 else
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4322 len = 0;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4323 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4324
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4325 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
4326 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4327 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
4328 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
4329
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4330 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
4331 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4332 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
4333 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
4334 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4335
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4336 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
4337 (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
4338 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
4339 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4340 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
4341 {
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4342 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
4343 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
4344 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4345 IObuff[len++] = '|';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4346 IObuff[len++] = ' ';
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4347
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4348 // 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
4349 // 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
4350 // 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
4351 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
4352 IObuff + len, IOSIZE - len);
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4353
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4354 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
4355 (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
4356 return FAIL;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4357
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4358 return OK;
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4359 }
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4360
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4361 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4362 * Fill current buffer with quickfix errors, replacing any previous contents.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4363 * 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
4364 * 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
4365 * 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
4366 * ml_delete() is used and autocommands will be triggered.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4367 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4368 static void
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4369 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
4370 {
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4371 linenr_T lnum;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4372 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
4373 int old_KeyTyped = KeyTyped;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4374
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4375 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4376 {
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4377 if (buf != curbuf)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4378 {
10359
66f1b5bf3fa6 commit https://github.com/vim/vim/commit/95f096030ed1a8afea028f2ea295d6f6a70f466f
Christian Brabandt <cb@256bit.org>
parents: 10349
diff changeset
4379 internal_error("qf_fill_buffer()");
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4380 return;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4381 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4382
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4383 // delete all existing lines
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4384 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
4385 (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
4386 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4387
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4388 // 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
4389 if (!qf_stack_empty(qi))
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4390 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4391 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
4392 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
4393
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
diff changeset
4394 *dirname = NUL;
31bb8e1f7625 patch 8.0.1781: file names in quickfix window are not shortened
Christian Brabandt <cb@256bit.org>
parents: 13802
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 // 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
4397 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4398 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4399 qfp = qfl->qf_start;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4400 lnum = 0;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4401 }
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4402 else
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4403 {
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4404 qfp = old_last->qf_next;
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4405 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
4406 }
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4407 while (lnum < qfl->qf_count)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4408 {
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4409 if (qf_buf_add_line(buf, lnum, qfp, dirname) == FAIL)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4410 break;
13992
710b1bb82f2c patch 8.1.0014: qf_init_ext() is too long
Christian Brabandt <cb@256bit.org>
parents: 13984
diff changeset
4411
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4412 ++lnum;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4413 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4414 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4415 break;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4416 }
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4417
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4418 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
4419 // 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
4420 (void)ml_delete(lnum + 1, FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4421 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4422
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4423 // correct cursor position
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4424 check_lnums(TRUE);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4425
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4426 if (old_last == NULL)
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4427 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4428 // 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
4429 // 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
4430 // using autocommands.
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4431 ++curbuf_lock;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4432 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
4433 curbuf->b_p_ma = FALSE;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4434
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4435 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
4436 apply_autocmds(EVENT_BUFREADPOST, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4437 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4438 apply_autocmds(EVENT_BUFWINENTER, (char_u *)"quickfix", NULL,
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4439 FALSE, curbuf);
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4440 keep_filetype = FALSE;
11589
39787def24bb patch 8.0.0677: setting 'filetype' may switch buffers
Christian Brabandt <cb@256bit.org>
parents: 11549
diff changeset
4441 --curbuf_lock;
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
4442
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4443 // 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
4444 redraw_curbuf_later(NOT_VALID);
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
4445 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4446
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4447 // Restore KeyTyped, setting 'filetype' may reset it.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4448 KeyTyped = old_KeyTyped;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4449 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4450
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4451 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
4452 * 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
4453 */
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4454 static void
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4455 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
4456 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4457 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
4458 }
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
4459
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4460 /*
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4461 * 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
4462 * 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
4463 */
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4464 static int
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4465 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
4466 {
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4467 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
4468
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4469 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
4470 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
4471 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
4472 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
4473 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4474
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
4475 /*
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4476 * 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
4477 * 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
4478 * 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
4479 * 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
4480 * 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
4481 */
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4482 static int
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4483 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
4484 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4485 int curlist;
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4486
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4487 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
4488 {
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4489 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
4490 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
4491 // 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
4492 return FAIL;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4493 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
4494 }
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4495 return OK;
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4496 }
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4497
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
4498 /*
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4499 * 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
4500 */
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4501 static void
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4502 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
4503 {
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4504 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
4505 return;
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4506
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
4507 // 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
4508 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
4509 qf_jump(qi, 0, 0, forceit);
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4510 }
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4511
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
4512 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4513 * Return TRUE when using ":vimgrep" for ":grep".
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4514 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4515 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4516 grep_internal(cmdidx_T cmdidx)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4517 {
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4518 return ((cmdidx == CMD_grep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4519 || cmdidx == CMD_lgrep
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4520 || cmdidx == CMD_grepadd
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
4521 || cmdidx == CMD_lgrepadd)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4522 && STRCMP("internal",
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4523 *curbuf->b_p_gp == NUL ? p_gp : curbuf->b_p_gp) == 0);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4524 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4525
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
4526 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4527 * 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
4528 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4529 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4530 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
4531 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4532 switch (cmdidx)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4533 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4534 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
4535 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
4536 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
4537 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
4538 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
4539 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
4540 default: return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4541 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4542 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4543
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4544 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4545 * Return the name for the errorfile, in allocated memory.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4546 * Find a new unique name when 'makeef' contains "##".
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4547 * Returns NULL for error.
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4548 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4549 static char_u *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4550 get_mef_name(void)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4551 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4552 char_u *p;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4553 char_u *name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4554 static int start = -1;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4555 static int off = 0;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4556 #ifdef HAVE_LSTAT
9387
f094d4085014 commit https://github.com/vim/vim/commit/8767f52fbfd4f053ce00a978227c95f1d7d323fe
Christian Brabandt <cb@256bit.org>
parents: 9379
diff changeset
4557 stat_T sb;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4558 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4559
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4560 if (*p_mef == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4561 {
6721
7347229a646a updated for version 7.4.684
Bram Moolenaar <bram@vim.org>
parents: 6450
diff changeset
4562 name = vim_tempname('e', FALSE);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4563 if (name == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4564 EMSG(_(e_notmp));
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4565 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4566 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4567
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4568 for (p = p_mef; *p; ++p)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4569 if (p[0] == '#' && p[1] == '#')
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4570 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4571
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4572 if (*p == NUL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4573 return vim_strsave(p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
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 // Keep trying until the name doesn't exist yet.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4576 for (;;)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4577 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4578 if (start == -1)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4579 start = mch_get_pid();
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4580 else
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4581 off += 19;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4582
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4583 name = alloc((unsigned)STRLEN(p_mef) + 30);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4584 if (name == NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4585 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4586 STRCPY(name, p_mef);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4587 sprintf((char *)name + (p - p_mef), "%d%d", start, off);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4588 STRCAT(name, p + 2);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4589 if (mch_getperm(name) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4590 #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
4591 // Don't accept a symbolic link, it's a security risk.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4592 && mch_lstat((char *)name, &sb) < 0
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4593 #endif
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4594 )
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4595 break;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4596 vim_free(name);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4597 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4598 return name;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4599 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4600
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4601 /*
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4602 * 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
4603 * 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
4604 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4605 static char_u *
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4606 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
4607 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4608 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4609 unsigned len;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4610
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4611 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
4612 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
4613 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
4614 cmd = alloc(len);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4615 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4616 return NULL;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4617 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
4618 (char *)p_shq);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4619
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4620 // 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
4621 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
4622 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
4623
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4624 // 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
4625 // 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
4626 // in column 0).
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4627 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
4628 msg_didout = FALSE;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4629 msg_start();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4630 MSG_PUTS(":!");
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4631 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
4632
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4633 return cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4634 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4635
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4636 /*
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4637 * 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
4638 */
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4639 void
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4640 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
4641 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4642 char_u *fname;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4643 char_u *cmd;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4644 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
4645 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
4646 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
4647 int res;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4648 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
4649 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
4650
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4651 // 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
4652 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
4653 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4654 ex_vimgrep(eap);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4655 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4656 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4657
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4658 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
4659 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
4660 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
4661 {
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4662 #ifdef FEAT_EVAL
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4663 if (aborting())
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4664 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4665 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4666 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4667 #ifdef FEAT_MBYTE
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4668 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
4669 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4670
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4671 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
4672 wp = curwin;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4673
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4674 autowrite_all();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4675 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
4676 if (fname == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4677 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4678 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
4679
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4680 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
4681 if (cmd == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4682 return;
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4683
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4684 // 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
4685 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
4686
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4687 #ifdef AMIGA
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4688 out_flush();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4689 // 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
4690 (void)char_avail();
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4691 #endif
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4692
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4693 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4694
14852
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4695 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
4696 && 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
4697 (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
4698 && 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
4699 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
4700 if (wp != NULL)
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 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
4703 if (qi == NULL)
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4704 goto cleanup;
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 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4707 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
4708
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4709 // 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
4710 // 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
4711 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
4712 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
4713 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
4714 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
4715 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
4716 // 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
4717 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
4718
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4719 cleanup:
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
4720 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
4721 mch_remove(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4722 vim_free(fname);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4723 vim_free(cmd);
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4724 }
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4725
3c8a4b25427c patch 8.1.0438: the ex_make() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14844
diff changeset
4726 /*
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4727 * 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
4728 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4729 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4730 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
4731 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4732 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
4733 qf_list_T *qfl;
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4734 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4735 int i, sz = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4736 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4737
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4738 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
4739 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4740 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4741 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4742 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4743 return 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4744 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4745
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
4746 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
4747 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
4748 ++i, qfp = qfp->qf_next)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4749 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4750 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4751 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4752 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
4753 sz++; // Count all valid entries
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4754 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
4755 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4756 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4757 sz++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4758 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4759 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4760 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4761 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4762
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4763 return sz;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4764 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4765
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4766 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4767 * 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
4768 * 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
4769 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4770 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4771 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
4772 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4773 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4774
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4775 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
4776 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4777 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4778 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4779 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4780 return 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4781 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4782
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4783 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
4784 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4785
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4786 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4787 * 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
4788 * 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
4789 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4790 int
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4791 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
4792 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4793 qf_info_T *qi = &ql_info;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4794 qf_list_T *qfl;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4795 qfline_T *qfp;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4796 int i, eidx = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4797 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4798
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4799 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
4800 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4801 // Location list
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4802 qi = GET_LOC_LIST(curwin);
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4803 if (qi == NULL)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4804 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4805 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4806
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4807 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
4808 qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4809
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4810 // 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
4811 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
4812 return 1;
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 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
4815 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4816 if (qfp->qf_valid)
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 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
4819 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4820 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
4821 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4822 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4823 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4824 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4825 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4826 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4827 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4828 eidx++;
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
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4832 return eidx ? eidx : 1;
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 /*
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4836 * 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
4837 * 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
4838 * 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
4839 * 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
4840 */
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4841 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
4842 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
4843 {
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4844 qfline_T *qfp = qfl->qf_start;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4845 int i, eidx;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4846 int prev_fnum = 0;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4847
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4848 // 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
4849 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
4850 return 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4851
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
4852 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
4853 i++, qfp = qfp->qf_next)
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 if (qfp->qf_valid)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4856 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4857 if (fdo)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4858 {
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4859 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
4860 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4861 // Count the number of files
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4862 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4863 prev_fnum = qfp->qf_fnum;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4864 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4865 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4866 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4867 eidx++;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4868 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4869
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4870 if (eidx == n)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4871 break;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4872 }
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4873
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4874 if (i <= qfl->qf_count)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4875 return i;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4876 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4877 return 1;
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 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4881 * ":cc", ":crewind", ":cfirst" and ":clast".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4882 * ":ll", ":lrewind", ":lfirst" and ":llast".
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4883 * ":cdo", ":ldo", ":cfdo" and ":lfdo"
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4884 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4885 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4886 ex_cc(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4887 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4888 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
4889 int errornr;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4890
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4891 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4892 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4893 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4894 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4895 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4896 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4897 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4898 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4899 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4900
7092
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4901 if (eap->addr_count > 0)
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4902 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4903 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4904 {
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4905 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4906 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4907 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
4908 errornr = 0;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4909 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4910 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
4911 case CMD_lfirst:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4912 errornr = 1;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4913 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4914 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4915 errornr = 32767;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4916 }
7092
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
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
4919 // 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
4920 // 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
4921 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
4922 || 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
4923 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
4924 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
4925 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
4926
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4927 qf_jump(qi, 0, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4928 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4929
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4930 /*
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4931 * ":cnext", ":cnfile", ":cNext" and ":cprevious".
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4932 * ":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
4933 * Also, used by ":cdo", ":ldo", ":cfdo" and ":lfdo" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4934 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4935 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4936 ex_cnext(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4937 {
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4938 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
4939 int errornr;
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4940 int dir;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4941
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4942 if (is_loclist_cmd(eap->cmdidx))
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4943 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4944 qi = GET_LOC_LIST(curwin);
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4945 if (qi == NULL)
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4946 {
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4947 EMSG(_(e_loclist));
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4948 return;
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4949 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4950 }
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4951
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
4952 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
4953 && (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
4954 && 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
4955 errornr = (int)eap->line2;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4956 else
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4957 errornr = 1;
64e30831fa42 commit https://github.com/vim/vim/commit/aa23b379421aa214e6543b06c974594a25799b09
Christian Brabandt <cb@256bit.org>
parents: 6853
diff changeset
4958
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4959 // 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
4960 switch (eap->cmdidx)
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4961 {
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4962 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
4963 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4964 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4965 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
4966 case CMD_lNext:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4967 dir = BACKWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4968 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4969 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
4970 dir = FORWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4971 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4972 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
4973 dir = BACKWARD_FILE;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4974 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4975 default:
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4976 dir = FORWARD;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4977 break;
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4978 }
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4979
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
4980 qf_jump(qi, dir, errornr, eap->forceit);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4981 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4982
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4983 /*
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
4984 * ":cfile"/":cgetfile"/":caddfile" commands.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4985 * ":lfile"/":lgetfile"/":laddfile" commands.
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4986 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4987 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
4988 ex_cfile(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
4989 {
11063
e71d3bdf3bc3 patch 8.0.0420: text garbled when the system encoding differs from 'encoding'
Christian Brabandt <cb@256bit.org>
parents: 10379
diff changeset
4990 char_u *enc = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4991 win_T *wp = NULL;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
4992 qf_info_T *qi = &ql_info;
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4993 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
4994 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
4995 int res;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
4996
3404
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4997 switch (eap->cmdidx)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4998 {
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
4999 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
5000 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
5001 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
5002 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
5003 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
5004 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
5005 default: break;
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5006 }
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5007 if (au_name != NULL)
38a135730423 updated for version 7.3.468
Bram Moolenaar <bram@vim.org>
parents: 3365
diff changeset
5008 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
5009 #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
5010 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
5011 #endif
2296
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5012 #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
5013 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
5014 {
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5015 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
5016 NULL, NULL,
378f9f8e6d8f patch 8.0.1773: dialog messages are not translated
Christian Brabandt <cb@256bit.org>
parents: 13800
diff changeset
5017 (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
5018 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
5019 return;
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5020 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
5021 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
5022 }
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5023 else
eb7be7b075a6 Support :browse for commands that use an error file argument. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2146
diff changeset
5024 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
5025 if (*eap->arg != NUL)
694
07d199fe02ed updated for version 7.0209
vimboss
parents: 682
diff changeset
5026 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
5027
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5028 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
5029 wp = curwin;
a1f8939a4644 patch 8.0.1414: accessing freed memory in :lfile.
Christian Brabandt <cb@256bit.org>
parents: 13076
diff changeset
5030
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5031 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5032
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5033 // 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
5034 // commands.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5035 // :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
5036 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5037 // :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
5038 // first error.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5039 // :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
5040 // 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
5041 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
5042 && 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
5043 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
5044 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
5045 {
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5046 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
5047 if (qi == NULL)
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5048 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5049 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
5050 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5051 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5052 }
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5053 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5054 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
5055 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
5056 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
5057 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
5058
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5059 // 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
5060 // 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
5061 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
5062 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5063 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
5064 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
5065
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5066 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
5067 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5068
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5069 /*
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5070 * 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
5071 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5072 static char_u *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5073 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
5074 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5075 switch (cmdidx)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5076 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5077 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
5078 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
5079 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
5080 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
5081 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
5082 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
5083 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
5084 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
5085 default: return NULL;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5086 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5087 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5088
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5089 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5090 * 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
5091 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5092 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5093 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
5094 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5095 // 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
5096 regmatch->regprog = NULL;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5097
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5098 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
5099 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5100 // 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
5101 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
5102 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5103 EMSG(_(e_noprevre));
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5104 return;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5105 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5106 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
5107 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5108 else
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5109 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
5110
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5111 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
5112 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
5113 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5114
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5115 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5116 * 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
5117 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5118 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5119 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
5120 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5121 char_u *p;
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 msg_start();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5124 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
5125 if (p == NULL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5126 msg_outtrans(fname);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5127 else
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5128 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5129 msg_outtrans(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5130 vim_free(p);
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5131 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5132 msg_clr_eos();
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5133 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
5134 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
5135 msg_col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5136 out_flush();
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
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 * 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
5141 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5142 static buf_T *
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5143 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
5144 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5145 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
5146 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
5147 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5148 int save_mls;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5149 #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
5150 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
5151 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5152 buf_T *buf;
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 #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
5155 // 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
5156 // 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
5157 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
5158 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5159 // 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
5160 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
5161 p_mls = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5162
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5163 // 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
5164 // 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
5165 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
5166
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5167 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
5168 #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
5169 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
5170 #endif
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5171
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5172 return buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5173 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5174
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5175 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5176 * 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
5177 * 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
5178 * new list.
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 static int
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5181 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
5182 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
5183 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
5184 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
5185 char_u *title)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5186 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5187 // 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
5188 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
5189 {
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5190 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
5191 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5192 // 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
5193 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
5194 return FALSE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5195 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5196 else
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5197 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5198 // 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
5199 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
5200 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
5201 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5202 }
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5203
14507
5a10a0020c3e patch 8.1.0267: no good check if restoring quickfix list worked
Christian Brabandt <cb@256bit.org>
parents: 14495
diff changeset
5204 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
5205 return FALSE;
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5206
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5207 return TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5208 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5209
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5210 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5211 * 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
5212 * 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
5213 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5214 static int
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5215 vgr_match_buflines(
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5216 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
5217 char_u *fname,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5218 buf_T *buf,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5219 regmmatch_T *regmatch,
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5220 long *tomatch,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5221 int duplicate_name,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5222 int flags)
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 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
5225 long lnum;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5226 colnr_T col;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5227
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5228 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
5229 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5230 col = 0;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5231 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
5232 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
5233 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5234 // 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
5235 // 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
5236 // 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
5237 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
5238 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5239 NULL, // dir
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5240 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
5241 NULL,
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5242 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
5243 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
5244 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
5245 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
5246 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
5247 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5248 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5249 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5250 0, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5251 TRUE // valid
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5252 ) == FAIL)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5253 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5254 got_int = TRUE;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5255 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5256 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5257 found_match = TRUE;
14976
676db1b7fc35 patch 8.1.0499: :2vimgrep causes an ml_get error
Bram Moolenaar <Bram@vim.org>
parents: 14956
diff changeset
5258 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
5259 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5260 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
5261 || 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
5262 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5263 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
5264 + (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
5265 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
5266 break;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5267 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5268 line_breakcheck();
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5269 if (got_int)
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5270 break;
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
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5273 return found_match;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5274 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5275
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5276 /*
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5277 * 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
5278 */
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5279 static void
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5280 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
5281 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
5282 int forceit,
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5283 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
5284 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
5285 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
5286 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5287 buf_T *buf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5288
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5289 buf = curbuf;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5290 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
5291 if (buf != curbuf)
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5292 // 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
5293 // 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
5294 *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
5295
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5296 // 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
5297 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
5298 {
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5299 exarg_T ea;
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5300
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5301 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
5302 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
5303 ex_cd(&ea);
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 }
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5306
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5307 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5308 * ":vimgrep {pattern} file(s)"
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5309 * ":vimgrepadd {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5310 * ":lvimgrep {pattern} file(s)"
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5311 * ":lvimgrepadd {pattern} file(s)"
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5312 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5313 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5314 ex_vimgrep(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5315 {
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5316 regmmatch_T regmatch;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5317 int fcount;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5318 char_u **fnames;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5319 char_u *fname;
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5320 char_u *title;
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5321 char_u *s;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5322 char_u *p;
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5323 int fi;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5324 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
5325 qf_list_T *qfl;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5326 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
5327 win_T *wp = NULL;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5328 buf_T *buf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5329 int duplicate_name = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5330 int using_dummy;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5331 int redraw_for_dummy = FALSE;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5332 int found_match;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5333 buf_T *first_match_buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5334 time_t seconds = 0;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5335 aco_save_T aco;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5336 int flags = 0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5337 long tomatch;
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5338 char_u *dirname_start = NULL;
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5339 char_u *dirname_now = NULL;
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5340 char_u *target_dir = NULL;
1683
75dbeedddaa9 updated for version 7.2b-016
vimboss
parents: 1672
diff changeset
5341 char_u *au_name = NULL;
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5342
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5343 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
5344 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
5345 curbuf->b_fname, TRUE, curbuf))
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5346 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5347 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
5348 if (aborting())
161
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5349 return;
6df0106fc595 updated for version 7.0049
vimboss
parents: 153
diff changeset
5350 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5351 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5352
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
5353 if (is_loclist_cmd(eap->cmdidx))
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5354 {
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5355 qi = ll_get_or_alloc_list(curwin);
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5356 if (qi == NULL)
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5357 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
5358 wp = curwin;
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5359 }
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
5360
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5361 if (eap->addr_count > 0)
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5362 tomatch = eap->line2;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5363 else
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5364 tomatch = MAXLNUM;
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5365
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5366 // Get the search pattern: either white-separated or enclosed in //
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5367 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
5368 title = vim_strsave(qf_cmdtitle(*eap->cmdlinep));
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5369 p = skip_vimgrep_pat(eap->arg, &s, &flags);
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5370 if (p == NULL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5371 {
282
33d9c918b8ab updated for version 7.0075
vimboss
parents: 277
diff changeset
5372 EMSG(_(e_invalpat));
153
19670b05ee32 updated for version 7.0047
vimboss
parents: 129
diff changeset
5373 goto theend;
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5374 }
4197
07fef68eb018 updated for version 7.3.850
Bram Moolenaar <bram@vim.org>
parents: 4003
diff changeset
5375
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5376 vgr_init_regmatch(&regmatch, s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5377 if (regmatch.regprog == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5378 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5379
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5380 p = skipwhite(p);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5381 if (*p == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5382 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5383 EMSG(_("E683: File name missing or invalid pattern"));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5384 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5385 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5386
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
5387 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
5388 && 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
5389 && 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
5390 || 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
5391 // 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
5392 qf_new_list(qi, title != NULL ? title : qf_cmdtitle(*eap->cmdlinep));
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5393
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5394 // parse the list of arguments
3620
4f1c511e71f8 updated for version 7.3.570
Bram Moolenaar <bram@vim.org>
parents: 3555
diff changeset
5395 if (get_arglist_exp(p, &fcount, &fnames, TRUE) == FAIL)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5396 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5397 if (fcount == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5398 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5399 EMSG(_(e_nomatch));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5400 goto theend;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5401 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5402
7558
9a4c9dccd603 commit https://github.com/vim/vim/commit/b86a343280b08d6701da68ee0651e960a0a7a61c
Christian Brabandt <cb@256bit.org>
parents: 7515
diff changeset
5403 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
5404 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
5405 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
5406 {
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5407 FreeWild(fcount, fnames);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5408 goto theend;
7662
4d34891e98f4 commit https://github.com/vim/vim/commit/61ff4dd6a4d47bd32383fe28087be2b37dec53f4
Christian Brabandt <cb@256bit.org>
parents: 7558
diff changeset
5409 }
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5410
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5411 // 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
5412 // ":lcd %:p:h" changes the meaning of short path names.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5413 mch_dirname(dirname_start, MAXPATHL);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5414
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5415 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5416
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5417 // 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
5418 // 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
5419 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
5420
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5421 seconds = (time_t)0;
716
8ae24f338cab updated for version 7.0217
vimboss
parents: 712
diff changeset
5422 for (fi = 0; fi < fcount && !got_int && tomatch > 0; ++fi)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5423 {
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5424 fname = shorten_fname1(fnames[fi]);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5425 if (time(NULL) > seconds)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5426 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5427 // 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
5428 // working on it.
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5429 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
5430 vgr_display_fname(fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5431 }
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5432
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5433 buf = buflist_findname_exp(fnames[fi]);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5434 if (buf == NULL || buf->b_ml.ml_mfp == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5435 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5436 // Remember that a buffer with this name already exists.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5437 duplicate_name = (buf != NULL);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5438 using_dummy = TRUE;
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5439 redraw_for_dummy = TRUE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5440
13521
15c856a1617b patch 8.0.1634: the ex_vimgrep() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13497
diff changeset
5441 buf = vgr_load_dummy_buf(fname, dirname_start, dirname_now);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5442 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5443 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5444 // Use existing, loaded buffer.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5445 using_dummy = FALSE;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5446
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5447 // 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
5448 // 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
5449 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
5450 {
2d94fcb0277d patch 8.0.1702: leaking memory when autocommands make quickfix list invalid
Christian Brabandt <cb@256bit.org>
parents: 13612
diff changeset
5451 FreeWild(fcount, fnames);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5452 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
5453 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
5454 }
13594
4d55eb79178b patch 8.0.1669: :vimgrep may add entries to the wrong quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13521
diff changeset
5455 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
5456
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5457 if (buf == NULL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5458 {
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5459 if (!got_int)
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5460 smsg((char_u *)_("Cannot open file \"%s\""), fname);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5461 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5462 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5463 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5464 // 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
5465 // 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
5466 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
5467 &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
5468
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5469 if (using_dummy)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5470 {
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5471 if (found_match && first_match_buf == NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5472 first_match_buf = buf;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5473 if (duplicate_name)
123
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 // 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
5476 // with the same name.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5477 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5478 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5479 }
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5480 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
5481 || 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
5482 || 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
5483 || buf->b_p_bh[0] == 'd') // "delete"
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5484 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5485 // 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
5486 // 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
5487 // 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
5488 // unload the buffer.
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5489 // 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
5490 // many swap files.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5491 if (!found_match)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5492 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5493 wipe_dummy_buffer(buf, dirname_start);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5494 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5495 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5496 else if (buf != first_match_buf || (flags & VGR_NOJUMP))
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5497 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5498 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
5499 // 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
5500 buf->b_flags &= ~BF_DUMMY;
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5501 buf = NULL;
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5502 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5503 }
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5504
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5505 if (buf != NULL)
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5506 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5507 // 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
5508 buf->b_flags &= ~BF_DUMMY;
64a791c53418 commit https://github.com/vim/vim/commit/015102e91e978a0bb42a14461c132a85e8f7e1ea
Christian Brabandt <cb@256bit.org>
parents: 9538
diff changeset
5509
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5510 // 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
5511 // directory we jumped to below.
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5512 if (buf == first_match_buf
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5513 && target_dir == NULL
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5514 && STRCMP(dirname_start, dirname_now) != 0)
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5515 target_dir = vim_strsave(dirname_now);
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5516
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5517 // 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
5518 // 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
5519 // 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
5520 // options!
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5521 aucmd_prepbuf(&aco, buf);
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5522 #if defined(FEAT_SYN_HL)
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5523 apply_autocmds(EVENT_FILETYPE, buf->b_p_ft,
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5524 buf->b_fname, TRUE, buf);
677
e649c78407e6 updated for version 7.0202
vimboss
parents: 665
diff changeset
5525 #endif
717
2fa8cb05b861 updated for version 7.0218
vimboss
parents: 716
diff changeset
5526 do_modelines(OPT_NOWIN);
123
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5527 aucmd_restbuf(&aco);
f67f8a8d81ba updated for version 7.0043
vimboss
parents: 119
diff changeset
5528 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5529 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5530 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5531 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5532
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5533 FreeWild(fcount, fnames);
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5534
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5535 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
5536 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5537 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
5538 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
5539 qf_list_changed(qfl);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5540
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
5541 qf_update_buffer(qi, NULL);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5542
842
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5543 if (au_name != NULL)
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5544 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
a209672376fd updated for version 7.0f
vimboss
parents: 835
diff changeset
5545 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
5546 // 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
5547 // is still valid.
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5548 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
5549 || 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
5550 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5551 decr_quickfix_busy();
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
5552 goto theend;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5553 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
5554
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
5555 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5556 if (!qf_list_empty(qi, qi->qf_curlist))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5557 {
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5558 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
5559 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
5560 first_match_buf, target_dir);
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5561 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5562 else
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5563 EMSG2(_(e_nomatch2), s);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5564
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5565 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
5566
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5567 // 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
5568 // may have messed up things, need to redraw and recompute folds.
1396
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5569 if (redraw_for_dummy)
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5570 {
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5571 #ifdef FEAT_FOLDING
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5572 foldUpdateAll(curwin);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5573 #else
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5574 redraw_later(NOT_VALID);
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5575 #endif
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5576 }
3e0f9984e98e updated for version 7.1-111
vimboss
parents: 1302
diff changeset
5577
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5578 theend:
8603
bfa74b84c41c commit https://github.com/vim/vim/commit/5584df65a0ca2315d1eebc13c54a448bee4d0758
Christian Brabandt <cb@256bit.org>
parents: 7833
diff changeset
5579 vim_free(title);
2770
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5580 vim_free(dirname_now);
25672ad7f377 updated for version 7.3.161
Bram Moolenaar <bram@vim.org>
parents: 2651
diff changeset
5581 vim_free(dirname_start);
1411
0e6b369b9760 updated for version 7.1-126
vimboss
parents: 1396
diff changeset
5582 vim_free(target_dir);
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
5583 vim_regfree(regmatch.regprog);
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5584 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5585
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
5586 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5587 * 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
5588 * 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
5589 */
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5590 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5591 restore_start_dir(char_u *dirname_start)
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5592 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5593 char_u *dirname_now = alloc(MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5594
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5595 if (NULL != dirname_now)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5596 {
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5597 mch_dirname(dirname_now, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5598 if (STRCMP(dirname_start, dirname_now) != 0)
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5599 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5600 // 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
5601 // appropriate ex command and executing it.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5602 exarg_T ea;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5603
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5604 ea.arg = dirname_start;
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5605 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
5606 ex_cd(&ea);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5607 }
3974
4d1753f3e85c updated for version 7.3.742
Bram Moolenaar <bram@vim.org>
parents: 3965
diff changeset
5608 vim_free(dirname_now);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5609 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5610 }
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5611
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5612 /*
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5613 * 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
5614 * 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
5615 * "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
5616 * 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
5617 * 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
5618 *
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5619 * 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
5620 * or wipe_dummy_buffer() later!
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5621 *
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5622 * Returns NULL if it fails.
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5623 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5624 static buf_T *
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5625 load_dummy_buffer(
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5626 char_u *fname,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5627 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
5628 char_u *resulting_dir) // out: new directory
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5629 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5630 buf_T *newbuf;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5631 bufref_T newbufref;
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5632 bufref_T newbuf_to_wipe;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5633 int failed = TRUE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5634 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
5635 int readfile_result;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5636
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5637 // Allocate a buffer without putting it in the buffer list.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5638 newbuf = buflist_new(NULL, NULL, (linenr_T)1, BLN_DUMMY);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5639 if (newbuf == NULL)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5640 return NULL;
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5641 set_bufref(&newbufref, newbuf);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5642
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5643 // Init the options.
177
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5644 buf_copy_options(newbuf, BCO_ENTER | BCO_NOHELP);
84c21eb4fc40 updated for version 7.0054
vimboss
parents: 170
diff changeset
5645
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5646 // 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
5647 if (ml_open(newbuf) == OK)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5648 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5649 // 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
5650 ++newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5651
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5652 // set curwin/curbuf to buf and save a few things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5653 aucmd_prepbuf(&aco, newbuf);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5654
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5655 // Need to set the filename for autocommands.
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5656 (void)setfname(curbuf, fname, NULL, FALSE);
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5657
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5658 // Create swap file now to avoid the ATTENTION message.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5659 check_need_swap(TRUE);
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5660
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5661 // 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
5662 // work.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5663 curbuf->b_flags &= ~BF_DUMMY;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5664
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5665 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
5666 readfile_result = readfile(fname, NULL,
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5667 (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
5668 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
5669 --newbuf->b_locked;
b931b2751650 patch 8.0.1403: using freed buffer in grep command
Christian Brabandt <cb@256bit.org>
parents: 13026
diff changeset
5670 if (readfile_result == OK
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5671 && !got_int
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5672 && !(curbuf->b_flags & BF_NEW))
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5673 {
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5674 failed = FALSE;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5675 if (curbuf != newbuf)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5676 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5677 // 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
5678 // 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
5679 // 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
5680 // window stuff.
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5681 set_bufref(&newbuf_to_wipe, newbuf);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5682 newbuf = curbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5683 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5684 }
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5685
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5686 // restore curwin/curbuf and a few other things
1918
eac2556d4620 updated for version 7.2-215
vimboss
parents: 1883
diff changeset
5687 aucmd_restbuf(&aco);
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5688 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
5689 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
5690
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5691 // 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
5692 // skip it.
9485
c16e207dc465 commit https://github.com/vim/vim/commit/ea3f2e7be447a8f0c4436869620f908de5e8ef1e
Christian Brabandt <cb@256bit.org>
parents: 9475
diff changeset
5693 newbuf->b_flags |= BF_DUMMY;
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5694 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5695
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5696 // 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
5697 // 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
5698 // important.
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5699 mch_dirname(resulting_dir, MAXPATHL);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5700 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5701
9487
69ed2c9d34a6 commit https://github.com/vim/vim/commit/7c0a2f367f2507669560b1a66423155c70d2e75b
Christian Brabandt <cb@256bit.org>
parents: 9485
diff changeset
5702 if (!bufref_valid(&newbufref))
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5703 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5704 if (failed)
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5705 {
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5706 wipe_dummy_buffer(newbuf, dirname_start);
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5707 return NULL;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5708 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5709 return newbuf;
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5710 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5711
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5712 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5713 * 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
5714 * 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
5715 * 'autochdir' option have changed it.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5716 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5717 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5718 wipe_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5719 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5720 if (curbuf != buf) // safety check
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5721 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5722 #if defined(FEAT_EVAL)
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5723 cleanup_T cs;
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
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 // 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
5726 // 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
5727 // work when got_int is set.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5728 enter_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5729 #endif
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5730
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5731 wipe_buffer(buf, FALSE);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5732
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
5733 #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
5734 // 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
5735 // new aborting error, interrupt, or uncaught exception.
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5736 leave_cleanup(&cs);
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5737 #endif
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5738 // 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
5739 restore_start_dir(dirname_start);
857
b933657f7c9d updated for version 7.0g01
vimboss
parents: 856
diff changeset
5740 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5741 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5742
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5743 /*
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5744 * 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
5745 * 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
5746 * 'autochdir' option have changed it.
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5747 */
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5748 static void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
5749 unload_dummy_buffer(buf_T *buf, char_u *dirname_start)
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5750 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5751 if (curbuf != buf) // safety check
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5752 {
3365
9ccdc4a69d8f updated for version 7.3.449
Bram Moolenaar <bram@vim.org>
parents: 3269
diff changeset
5753 close_buffer(NULL, buf, DOBUF_UNLOAD, FALSE);
3490
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5754
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5755 // 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
5756 restore_start_dir(dirname_start);
8101253704f6 updated for version 7.3.509
Bram Moolenaar <bram@vim.org>
parents: 3404
diff changeset
5757 }
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5758 }
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
5759
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5760 #if defined(FEAT_EVAL) || defined(PROTO)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5761 /*
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5762 * 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
5763 * 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
5764 */
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5765 int
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5766 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
5767 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5768 qf_info_T *qi = qi_arg;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5769 dict_T *dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5770 char_u buf[2];
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5771 qfline_T *qfp;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5772 int i;
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5773 int bufnum;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5774
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5775 if (qi == NULL)
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5776 {
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5777 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
5778 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
5779 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5780 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
5781 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
5782 return FAIL;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5783 }
647
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5784 }
19106f131c87 updated for version 7.0188
vimboss
parents: 644
diff changeset
5785
13800
e4dc4ede9ef8 patch 8.0.1772: quickfix: mixup of FALSE and FAIL, returning -1
Christian Brabandt <cb@256bit.org>
parents: 13764
diff changeset
5786 if (qf_idx == INVALID_QFIDX)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5787 qf_idx = qi->qf_curlist;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5788
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
5789 if (qf_idx >= qi->qf_listcount || qf_list_empty(qi, qf_idx))
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5790 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5791
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5792 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
5793 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
5794 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5795 // Handle entries with a non-existing buffer number.
1065
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5796 bufnum = qfp->qf_fnum;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5797 if (bufnum != 0 && (buflist_findnr(bufnum) == NULL))
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5798 bufnum = 0;
caa550fe4457 updated for version 7.0-191
vimboss
parents: 1020
diff changeset
5799
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5800 if ((dict = dict_alloc()) == NULL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5801 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5802 if (list_append_dict(list, dict) == FAIL)
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5803 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5804
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5805 buf[0] = qfp->qf_type;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5806 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
5807 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
5808 || 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
5809 || 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
5810 || 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
5811 || 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
5812 || 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
5813 || 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
5814 || 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
5815 || 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
5816 || dict_add_number(dict, "valid", (long)qfp->qf_valid) == FAIL)
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5817 return FAIL;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5818
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5819 qfp = qfp->qf_next;
9195
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5820 if (qfp == NULL)
543f068f3706 commit https://github.com/vim/vim/commit/83e6d7ac6a1c2a0cb5ee6c8420a5dc792f1d5ffa
Christian Brabandt <cb@256bit.org>
parents: 9175
diff changeset
5821 break;
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5822 }
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5823 return OK;
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
5824 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5825
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5826 // 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
5827 enum {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5828 QF_GETLIST_NONE = 0x0,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5829 QF_GETLIST_TITLE = 0x1,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5830 QF_GETLIST_ITEMS = 0x2,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5831 QF_GETLIST_NR = 0x4,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5832 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
5833 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
5834 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
5835 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
5836 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
5837 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
5838 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
5839 QF_GETLIST_ALL = 0x3FF,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5840 };
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5841
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5842 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5843 * 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
5844 * 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
5845 */
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5846 static int
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5847 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
5848 {
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5849 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
5850 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
5851 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
5852 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
5853 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
5854
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5855 // 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
5856 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
5857 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5858 // 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
5859 // option setting
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5860 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
5861 {
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5862 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
5863 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
5864 return FAIL;
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5865 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
5866 }
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5867
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5868 l = list_alloc();
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5869 if (l == NULL)
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5870 return FAIL;
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5871
14495
178162aeebeb patch 8.1.0261: Coverity complains about a negative array index
Christian Brabandt <cb@256bit.org>
parents: 14491
diff changeset
5872 qi = ll_new_list();
12252
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5873 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
5874 {
12321
2779d593a706 patch 8.0.1040: cannot use another error format in getqflist()
Christian Brabandt <cb@256bit.org>
parents: 12303
diff changeset
5875 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
5876 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
5877 {
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5878 (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
5879 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
5880 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5881 free(qi);
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5882 }
12299
f4d00472e617 patch 8.0.1029: return value of getqflist() is inconsistent
Christian Brabandt <cb@256bit.org>
parents: 12287
diff changeset
5883 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
5884 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
5885 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5886
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5887 return status;
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5888 }
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5889
3d0e042ec13c patch 8.0.1006: quickfix list changes when parsing text with 'erroformat'
Christian Brabandt <cb@256bit.org>
parents: 12146
diff changeset
5890 /*
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
5891 * 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
5892 */
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5893 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
5894 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
5895 {
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5896 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
5897
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5898 // 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
5899 // 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
5900 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
5901 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
5902 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
5903 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
5904 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
5905 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
5906 }
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5907
9812a9ca3ab2 patch 8.0.1432: after ":copen" can't get the window-ID of the quickfix window
Christian Brabandt <cb@256bit.org>
parents: 13105
diff changeset
5908 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5909 * Convert the keys in 'what' to quickfix list property flags.
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
5910 */
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5911 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
5912 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
5913 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5914 int flags = QF_GETLIST_NONE;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
5915
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5916 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
5917 {
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5918 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
5919 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
5920 // 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
5921 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
5922 }
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5923
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5924 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
5925 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
5926
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5927 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
5928 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
5929
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5930 if (dict_find(what, (char_u *)"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
5931 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
5932
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5933 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
5934 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
5935
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5936 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
5937 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
5938
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
5939 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
5940 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
5941
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
5942 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
5943 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
5944
805f7fd40e0d patch 8.0.1112: can't get size or current index from quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12449
diff changeset
5945 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
5946 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
5947
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
5948 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
5949 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
5950
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
5951 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
5952 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
5953
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5954 return flags;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5955 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5956
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5957 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5958 * 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
5959 * 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
5960 * quickfix list index.
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5961 * 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
5962 * 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
5963 * 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
5964 * 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
5965 * 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
5966 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5967 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5968 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
5969 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5970 int qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5971 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5972
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5973 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
5974 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
5975 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5976 // 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
5977 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
5978 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5979 // 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
5980 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
5981 {
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5982 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
5983 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
5984 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
5985 }
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
5986 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5987 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
5988 && 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
5989 && 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
5990 // 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
5991 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
5992 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
5993 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
5994 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5995
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
5996 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
5997 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
5998 // 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
5999 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
6000 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6001 // 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
6002 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
6003 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
6004 }
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6005 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6006 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
6007 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6008
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6009 return qf_idx;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6010 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6011
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6012 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6013 * 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
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_defaults(qf_info_T *qi, int flags, dict_T *retdict)
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 status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6019
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6020 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
6021 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
6022 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
6023 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6024 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
6025 if (l != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6026 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
6027 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6028 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6029 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6030 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
6031 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
6032 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
6033 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
6034 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
6035 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
6036 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
6037 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
6038 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
6039 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
6040 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
6041 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
6042 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
6043 status = dict_add_number(retdict, "changedtick", 0);
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6044 if ((status == OK) && IS_LL_STACK(qi) && (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
6045 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
6046
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6047 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6048 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6049
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6050 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6051 * 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
6052 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6053 static int
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6054 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
6055 {
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6056 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
6057 }
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 /*
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
6060 * 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
6061 * 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
6062 * 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
6063 */
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6064 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
6065 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
6066 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6067 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
6068
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6069 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
6070 {
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6071 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
6072 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
6073 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
6074 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6075
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6076 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
6077 }
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6078
8770189c3e22 patch 8.1.0345: cannot get the window id associated with the location list
Christian Brabandt <cb@256bit.org>
parents: 14633
diff changeset
6079 /*
13710
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6080 * 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
6081 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6082 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6083 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
6084 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6085 int status = OK;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6086 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
6087 if (l != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6088 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6089 (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
6090 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
6091 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6092 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6093 status = FAIL;
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 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
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_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
6103 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6104 int status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6105 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6106
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6107 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
6108 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6109 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
6110 if (di != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6111 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6112 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
6113 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
6114 if (status == FAIL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6115 dictitem_free(di);
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6116 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6117 else
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6118 status = FAIL;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6119 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6120 else
14301
3c80092eb211 patch 8.1.0166: using dict_add_nr_str() is clumsy
Christian Brabandt <cb@256bit.org>
parents: 14299
diff changeset
6121 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
6122
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6123 return status;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6124 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6125
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6126 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6127 * 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
6128 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6129 static int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6130 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
6131 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6132 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
6133 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
6134 // 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
6135 curidx = 0;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6136 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
6137 }
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6138
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6139 /*
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6140 * 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
6141 * 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
6142 * 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
6143 */
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6144 int
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6145 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
6146 {
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6147 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
6148 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
6149 int status = OK;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6150 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
6151 dictitem_T *di;
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6152 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
6153
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6154 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
6155 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
6156
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6157 if (wp != NULL)
b33f04873475 patch 8.0.1727: qf_get_properties() function is too long
Christian Brabandt <cb@256bit.org>
parents: 13660
diff changeset
6158 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
6159
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
6160 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
6161
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6162 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
6163 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
6164
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6165 // 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
6166 if (qf_stack_empty(qi) || 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
6167 return qf_getprop_defaults(qi, flags, retdict);
13026
7c0e0e923537 patch 8.0.1389: getqflist() items are missing if not set
Christian Brabandt <cb@256bit.org>
parents: 13016
diff changeset
6168
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
6169 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
6170
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6171 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
6172 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
6173 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
6174 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
6175 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
6176 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
6177 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
6178 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
6179 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
6180 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
6181 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
6182 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
6183 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
6184 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
6185 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
6186 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
6187 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
6188 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
6189 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
6190 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
6191
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6192 return status;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6193 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6194
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6195 /*
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6196 * Add a new quickfix entry to list at 'qf_idx' in the stack 'qi' from the
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6197 * items in the dict 'd'.
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6198 */
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6199 static int
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6200 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
6201 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
6202 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
6203 dict_T *d,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6204 int first_entry)
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6205 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6206 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
6207 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
6208 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
6209 long lnum;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6210
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6211 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
6212 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
6213
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6214 filename = get_dict_string(d, (char_u *)"filename", TRUE);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6215 module = get_dict_string(d, (char_u *)"module", TRUE);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6216 bufnum = (int)get_dict_number(d, (char_u *)"bufnr");
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6217 lnum = (int)get_dict_number(d, (char_u *)"lnum");
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6218 col = (int)get_dict_number(d, (char_u *)"col");
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6219 vcol = (int)get_dict_number(d, (char_u *)"vcol");
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6220 nr = (int)get_dict_number(d, (char_u *)"nr");
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6221 type = get_dict_string(d, (char_u *)"type", TRUE);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6222 pattern = get_dict_string(d, (char_u *)"pattern", TRUE);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6223 text = get_dict_string(d, (char_u *)"text", TRUE);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6224 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
6225 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
6226
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6227 valid = TRUE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6228 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
6229 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6230
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6231 // 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
6232 // 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
6233 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
6234 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6235 if (!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
6236 {
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6237 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
6238 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
6239 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6240 valid = FALSE;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6241 bufnum = 0;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6242 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6243
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6244 // 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
6245 if ((dict_find(d, (char_u *)"valid", -1)) != NULL)
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6246 valid = (int)get_dict_number(d, (char_u *)"valid");
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 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
6249 qf_idx,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6250 NULL, // dir
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6251 filename,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6252 module,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6253 bufnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6254 text,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6255 lnum,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6256 col,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6257 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
6258 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
6259 nr,
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6260 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
6261 valid);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6262
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6263 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
6264 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
6265 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
6266 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
6267 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
6268
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6269 return status;
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6270 }
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6271
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6272 /*
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6273 * 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
6274 * a dictionary with item information.
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6275 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6276 static int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6277 qf_add_entries(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6278 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
6279 int qf_idx,
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6280 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6281 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6282 int action)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6283 {
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
6284 qf_list_T *qfl = &qi->qf_lists[qf_idx];
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6285 listitem_T *li;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6286 dict_T *d;
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
6287 qfline_T *old_last = NULL;
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6288 int retval = OK;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6289
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6290 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
6291 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6292 // make place for a new list
3965
eccae034465b updated for version 7.3.738
Bram Moolenaar <bram@vim.org>
parents: 3949
diff changeset
6293 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
6294 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
6295 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
6296 }
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
6297 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
6298 // 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
6299 old_last = qfl->qf_last;
277
fe16c18c24a7 updated for version 7.0074
vimboss
parents: 273
diff changeset
6300 else if (action == 'r')
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6301 {
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
6302 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
6303 qf_store_title(qfl, title);
6079
75ae211df37d updated for version 7.4.378
Bram Moolenaar <bram@vim.org>
parents: 5753
diff changeset
6304 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6305
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6306 for (li = list->lv_first; li != NULL; li = li->li_next)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6307 {
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6308 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
6309 continue; // Skip non-dict items
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6310
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6311 d = li->li_tv.vval.v_dict;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6312 if (d == NULL)
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6313 continue;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6314
14633
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6315 retval = qf_add_entry_from_dict(qi, qf_idx, d, li == list->lv_first);
462087b5c415 patch 8.1.0330: the qf_add_entries() function is too long
Christian Brabandt <cb@256bit.org>
parents: 14603
diff changeset
6316 if (retval == FAIL)
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6317 break;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6318 }
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6319
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
6320 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
6321 // 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
6322 qfl->qf_nonevalid = TRUE;
2146
c17a42da3920 updated for version 7.2.428
Bram Moolenaar <bram@zimbu.org>
parents: 2047
diff changeset
6323 else
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
6324 qfl->qf_nonevalid = FALSE;
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6325 if (action != 'a')
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6326 {
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
6327 qfl->qf_ptr = qfl->qf_start;
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
6328 if (!qf_list_empty(qi, qf_idx))
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
6329 qfl->qf_index = 1;
8932
25c2031e9f9f commit https://github.com/vim/vim/commit/c1808d5822ed9534ef7f0fe509b15bee92a5cc28
Christian Brabandt <cb@256bit.org>
parents: 8751
diff changeset
6330 }
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6331
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6332 // Don't update the cursor in quickfix window when appending entries
9175
d415c079f84e commit https://github.com/vim/vim/commit/864293abb72d62604d8d6b458addfb43c14230c3
Christian Brabandt <cb@256bit.org>
parents: 9114
diff changeset
6333 qf_update_buffer(qi, old_last);
230
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6334
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6335 return retval;
9281a51ca7a2 updated for version 7.0064
vimboss
parents: 189
diff changeset
6336 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6337
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6338 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6339 * Get the quickfix list index from 'nr' or 'id'
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6340 */
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6341 static int
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6342 qf_setprop_get_qfidx(
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6343 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6344 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6345 int action,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6346 int *newlist)
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6347 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6348 dictitem_T *di;
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6349 int qf_idx = qi->qf_curlist; // default is the current list
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6350
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6351 if ((di = dict_find(what, (char_u *)"nr", -1)) != NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6352 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6353 // Use the specified quickfix/location list
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6354 if (di->di_tv.v_type == VAR_NUMBER)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6355 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6356 // for zero use the current list
11445
461ac47c3793 patch 8.0.0606: cannot set the context for a specified quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11443
diff changeset
6357 if (di->di_tv.vval.v_number != 0)
461ac47c3793 patch 8.0.0606: cannot set the context for a specified quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11443
diff changeset
6358 qf_idx = di->di_tv.vval.v_number - 1;
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6359
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6360 if ((action == ' ' || action == 'a') && qf_idx == qi->qf_listcount)
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6361 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6362 // When creating a new list, accept qf_idx pointing to the next
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6363 // non-available list and add the new list at the end of the
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6364 // stack.
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6365 *newlist = TRUE;
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6366 qf_idx = qf_stack_empty(qi) ? 0 : qi->qf_listcount - 1;
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6367 }
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6368 else if (qf_idx < 0 || qf_idx >= qi->qf_listcount)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6369 return INVALID_QFIDX;
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6370 else if (action != ' ')
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6371 *newlist = FALSE; // use the specified list
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6372 }
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6373 else if (di->di_tv.v_type == VAR_STRING
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6374 && di->di_tv.vval.v_string != NULL
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6375 && STRCMP(di->di_tv.vval.v_string, "$") == 0)
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6376 {
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6377 if (!qf_stack_empty(qi))
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6378 qf_idx = qi->qf_listcount - 1;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6379 else if (*newlist)
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6380 qf_idx = 0;
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6381 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6382 return INVALID_QFIDX;
11549
f5add45f9848 patch 8.0.0657: cannot get and set quickfix list items
Christian Brabandt <cb@256bit.org>
parents: 11521
diff changeset
6383 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6384 else
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6385 return INVALID_QFIDX;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6386 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6387
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6388 if (!*newlist && (di = dict_find(what, (char_u *)"id", -1)) != NULL)
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
6389 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6390 // Use the quickfix/location list with the specified id
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6391 if (di->di_tv.v_type != VAR_NUMBER)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6392 return INVALID_QFIDX;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6393
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6394 return qf_id2nr(qi, di->di_tv.vval.v_number);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6395 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6396
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6397 return qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6398 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6399
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6400 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6401 * Set the quickfix list title.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6402 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6403 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6404 qf_setprop_title(qf_info_T *qi, int qf_idx, dict_T *what, dictitem_T *di)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6405 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6406 qf_list_T *qfl = &qi->qf_lists[qf_idx];
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6407
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6408 if (di->di_tv.v_type != VAR_STRING)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6409 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6410
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6411 vim_free(qfl->qf_title);
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6412 qfl->qf_title = get_dict_string(what, (char_u *)"title", TRUE);
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6413 if (qf_idx == qi->qf_curlist)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6414 qf_update_win_titlevar(qi);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6415
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6416 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6417 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6418
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6419 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6420 * Set quickfix list items/entries.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6421 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6422 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6423 qf_setprop_items(qf_info_T *qi, int qf_idx, dictitem_T *di, int action)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6424 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6425 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6426 char_u *title_save;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6427
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6428 if (di->di_tv.v_type != VAR_LIST)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6429 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6430
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6431 title_save = vim_strsave(qi->qf_lists[qf_idx].qf_title);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6432 retval = qf_add_entries(qi, qf_idx, di->di_tv.vval.v_list,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6433 title_save, action == ' ' ? 'a' : action);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6434 vim_free(title_save);
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6435
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6436 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6437 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6438
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6439 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6440 * Set quickfix list items/entries from a list of lines.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6441 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6442 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6443 qf_setprop_items_from_lines(
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6444 qf_info_T *qi,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6445 int qf_idx,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6446 dict_T *what,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6447 dictitem_T *di,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6448 int action)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6449 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6450 char_u *errorformat = p_efm;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6451 dictitem_T *efm_di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6452 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6453
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6454 // Use the user supplied errorformat settings (if present)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6455 if ((efm_di = dict_find(what, (char_u *)"efm", -1)) != NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6456 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6457 if (efm_di->di_tv.v_type != VAR_STRING ||
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6458 efm_di->di_tv.vval.v_string == NULL)
12287
20641a7e1fc9 patch 8.0.1023: it is not easy to identify a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 12252
diff changeset
6459 return FAIL;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6460 errorformat = efm_di->di_tv.vval.v_string;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6461 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6462
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6463 // Only a List value is supported
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6464 if (di->di_tv.v_type != VAR_LIST || di->di_tv.vval.v_list == NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6465 return FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6466
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6467 if (action == 'r')
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6468 qf_free_items(&qi->qf_lists[qf_idx]);
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6469 if (qf_init_ext(qi, qf_idx, NULL, NULL, &di->di_tv, errorformat,
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6470 FALSE, (linenr_T)0, (linenr_T)0, NULL, NULL) > 0)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6471 retval = OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6472
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6473 return retval;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6474 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6475
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6476 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6477 * Set quickfix list context.
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6478 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6479 static int
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6480 qf_setprop_context(qf_list_T *qfl, dictitem_T *di)
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6481 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6482 typval_T *ctx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6483
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6484 free_tv(qfl->qf_ctx);
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6485 ctx = alloc_tv();
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6486 if (ctx != NULL)
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6487 copy_tv(&di->di_tv, ctx);
14790
3ca7aba1116e patch 8.1.0407: quickfix code mixes using the stack and a list pointer
Christian Brabandt <cb@256bit.org>
parents: 14664
diff changeset
6488 qfl->qf_ctx = ctx;
13760
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6489
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6490 return OK;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6491 }
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6492
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6493 /*
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6494 * 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
6495 * 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
6496 * 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
6497 */
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6498 static int
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6499 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
6500 {
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6501 dictitem_T *di;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6502 int retval = FAIL;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6503 int qf_idx;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6504 int newlist = FALSE;
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6505 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
6506
14887
863bdbc8465b patch 8.1.0455: checking for empty quickfix stack is not consistent
Bram Moolenaar <Bram@vim.org>
parents: 14852
diff changeset
6507 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
6508 newlist = TRUE;
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6509
aef8ba129a4f patch 8.0.1752: qf_set_properties() is to long
Christian Brabandt <cb@256bit.org>
parents: 13756
diff changeset
6510 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
6511 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
6512 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
6513
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6514 if (newlist)
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6515 {
12084
69ce6b3f0834 patch 8.0.0922: quickfix list always added after current one
Christian Brabandt <cb@256bit.org>
parents: 12048
diff changeset
6516 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
6517 qf_new_list(qi, title);
9982
e24aa20d815c commit https://github.com/vim/vim/commit/2b529bb6260b52246e92429375d995b9b5ce76b6
Christian Brabandt <cb@256bit.org>
parents: 9931
diff changeset
6518 qf_idx = qi->qf_curlist;
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6519 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6520
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6521 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
6522 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
6523 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
6524 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
6525 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
6526 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
6527 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
6528 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
6529 retval = qf_setprop_context(qfl, di);
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6530
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6531 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6532 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
6533
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6534 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6535 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6536
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6537 /*
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6538 * 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
6539 * 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
6540 */
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6541 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
6542 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
6543 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6544 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
6545
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6546 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
6547 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
6548 return wp;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6549
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6550 return NULL;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6551 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6552
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6553 /*
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6554 * 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
6555 * 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
6556 */
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6557 static void
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6558 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
6559 {
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6560 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
6561 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
6562 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
6563
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6564 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
6565 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6566 // 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
6567 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
6568 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
6569 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
6570 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6571
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6572 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
6573 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6574 // 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
6575 // 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
6576 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
6577 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
6578 wp = llwin;
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6579 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6580
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6581 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
6582 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
6583 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6584 // 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
6585 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
6586 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
6587 }
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6588 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
6589 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6590 // 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
6591 // location list
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6592 qf_info_T *new_ll = ll_new_list();
11378
2ed7a34ecc54 patch 8.0.0574: get only one quickfix list after :caddbuf
Christian Brabandt <cb@256bit.org>
parents: 11360
diff changeset
6593
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6594 // 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
6595 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
6596
11301
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6597 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
6598 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
6599 {
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6600 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
6601 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
6602 }
cc8ece2aa389 patch 8.0.0536: quickfix window not updated when freeing quickfix stack
Christian Brabandt <cb@256bit.org>
parents: 11263
diff changeset
6603 }
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6604 }
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6605
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6606 /*
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6607 * 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
6608 * 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
6609 * "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
6610 */
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6611 int
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6612 set_errorlist(
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6613 win_T *wp,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6614 list_T *list,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6615 int action,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6616 char_u *title,
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6617 dict_T *what)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6618 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6619 qf_info_T *qi = &ql_info;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6620 int retval = OK;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6621
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6622 if (wp != NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6623 {
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6624 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
6625 if (qi == NULL)
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6626 return FAIL;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6627 }
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6628
11263
ae5f9f26f81c patch 8.0.0517: there is no way to remove quickfix lists
Christian Brabandt <cb@256bit.org>
parents: 11195
diff changeset
6629 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
6630 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6631 // 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
6632 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
6633 return OK;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6634 }
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6635
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6636 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6637
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6638 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
6639 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
6640 else
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6641 {
11449
d2f00eb352b9 patch 8.0.0608: cannot manipulate other than the current quickfix list
Christian Brabandt <cb@256bit.org>
parents: 11447
diff changeset
6642 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
6643 if (retval == OK)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6644 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
6645 }
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6646
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6647 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6648
9850
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6649 return retval;
67781bb0a61a commit https://github.com/vim/vim/commit/d823fa910cca43fec3c31c030ee908a14c272640
Christian Brabandt <cb@256bit.org>
parents: 9738
diff changeset
6650 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6651
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6652 /*
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
6653 * 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
6654 */
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6655 static int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6656 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
6657 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6658 int i;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6659 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6660 typval_T *ctx;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6661
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6662 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
6663 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6664 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
6665 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
6666 && 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
6667 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
6668 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6669
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6670 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6671 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6672
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6673 /*
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6674 * 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
6675 * "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
6676 */
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6677 int
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6678 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
6679 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6680 int abort = FALSE;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6681 tabpage_T *tp;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6682 win_T *win;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6683
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6684 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
6685 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6686 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6687
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6688 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
6689 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6690 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
6691 {
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6692 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
6693 if (abort)
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6694 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6695 }
13074
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6696 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
6697 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6698 // 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
6699 // 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
6700 // 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
6701 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
6702 if (abort)
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6703 return abort;
66c014c71dad patch 8.0.1412: using free memory using setloclist()
Christian Brabandt <cb@256bit.org>
parents: 13066
diff changeset
6704 }
11412
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6705 }
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6706
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6707 return abort;
84baca75b7f2 patch 8.0.0590: cannot add a context to locations
Christian Brabandt <cb@256bit.org>
parents: 11398
diff changeset
6708 }
170
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6709 #endif
8c60f65311fa updated for version 7.0052
vimboss
parents: 167
diff changeset
6710
42
c75153d791d0 updated for version 7.0026
vimboss
parents: 41
diff changeset
6711 /*
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6712 * ":[range]cbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6713 * ":[range]caddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6714 * ":[range]cgetbuffer [bufnr]" command.
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6715 * ":[range]lbuffer [bufnr]" command.
657
b112ec5c73f0 updated for version 7.0193
vimboss
parents: 648
diff changeset
6716 * ":[range]laddbuffer [bufnr]" command.
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6717 * ":[range]lgetbuffer [bufnr]" command.
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6718 */
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6719 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6720 ex_cbuffer(exarg_T *eap)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6721 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6722 buf_T *buf = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6723 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
6724 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
6725 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
6726 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
6727 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6728
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6729 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6730 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6731 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
6732 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
6733 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
6734 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
6735 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
6736 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
6737 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6738 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6739 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
6740 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6741 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6742 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6743 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6744 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6745 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6746 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6747
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6748 // 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
6749 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
6750 {
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6751 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
6752 if (qi == NULL)
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6753 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6754 wp = curwin;
13076
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6755 }
7c071a3f7f8e patch 8.0.1413: accessing freed memory in :cbuffer
Christian Brabandt <cb@256bit.org>
parents: 13074
diff changeset
6756
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6757 if (*eap->arg == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6758 buf = curbuf;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6759 else if (*skipwhite(skipdigits(eap->arg)) == NUL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6760 buf = buflist_findnr(atoi((char *)eap->arg));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6761 if (buf == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6762 EMSG(_(e_invarg));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6763 else if (buf->b_ml.ml_mfp == NULL)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6764 EMSG(_("E681: Buffer is not loaded"));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6765 else
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6766 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6767 if (eap->addr_count == 0)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6768 {
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6769 eap->line1 = 1;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6770 eap->line2 = buf->b_ml.ml_line_count;
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6771 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6772 if (eap->line1 < 1 || eap->line1 > buf->b_ml.ml_line_count
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6773 || eap->line2 < 1 || eap->line2 > buf->b_ml.ml_line_count)
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6774 EMSG(_(e_invrange));
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6775 else
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6776 {
13921
3b6c29f8c1a2 patch 8.0.1831: sometimes the quickfix title is incorrectly prefixed with ':'
Christian Brabandt <cb@256bit.org>
parents: 13882
diff changeset
6777 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
6778
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6779 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
6780 {
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6781 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
6782 (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
6783 qf_title = IObuff;
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6784 }
68e394361ca3 Add "q" item for 'statusline'. Add w:quickfix_title. (Lech Lorens)
Bram Moolenaar <bram@vim.org>
parents: 2296
diff changeset
6785
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6786 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6787
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6788 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
6789 (eap->cmdidx != CMD_caddbuffer
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6790 && 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
6791 eap->line1, eap->line2,
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6792 qf_title, NULL);
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6793 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
6794 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6795 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6796 return;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6797 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6798 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6799 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
6800
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6801 // 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
6802 // 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
6803 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
6804 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
6805 {
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6806 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
6807
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6808 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
6809 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
6810 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
6811 // 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
6812 // be invalid.
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6813 res = 0;
59e76d550c10 patch 8.1.0060: crash when autocommands delete the current buffer
Christian Brabandt <cb@256bit.org>
parents: 13992
diff changeset
6814 }
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6815 // 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
6816 // free the list.
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6817 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
6818 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
6819 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6820 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6821 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
6822
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6823 decr_quickfix_busy();
661
e93a99ef31d0 updated for version 7.0195
vimboss
parents: 659
diff changeset
6824 }
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6825 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6826 }
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6827
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
6828 #if defined(FEAT_EVAL) || defined(PROTO)
41
f529edb9bab3 updated for version 7.0025
vimboss
parents: 26
diff changeset
6829 /*
798
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6830 * ":cexpr {expr}", ":cgetexpr {expr}", ":caddexpr {expr}" command.
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6831 * ":lexpr {expr}", ":lgetexpr {expr}", ":laddexpr {expr}" command.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6832 */
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6833 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
6834 ex_cexpr(exarg_T *eap)
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6835 {
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6836 typval_T *tv;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6837 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
6838 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
6839 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
6840 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
6841 win_T *wp = NULL;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
6842
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6843 switch (eap->cmdidx)
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6844 {
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6845 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
6846 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
6847 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
6848 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
6849 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
6850 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
6851 default: break;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6852 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6853 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
6854 curbuf->b_fname, TRUE, curbuf))
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6855 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6856 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
6857 if (aborting())
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6858 return;
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6859 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
6860 }
10056
21f685af3fc1 commit https://github.com/vim/vim/commit/04c4ce650f9e533cd35b2aa6803f4d354d3ec7aa
Christian Brabandt <cb@256bit.org>
parents: 10042
diff changeset
6861
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
6862 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
6863 {
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6864 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
6865 if (qi == NULL)
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6866 return;
14250
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6867 wp = curwin;
13090
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6868 }
a0c6910e7fa4 patch 8.0.1420: accessing freed memory in vimgrep
Christian Brabandt <cb@256bit.org>
parents: 13078
diff changeset
6869
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6870 // 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
6871 // use it to fill the errorlist.
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6872 tv = eval_expr(eap->arg, NULL);
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6873 if (tv != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6874 {
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6875 if ((tv->v_type == VAR_STRING && tv->vval.v_string != NULL)
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6876 || (tv->v_type == VAR_LIST && tv->vval.v_list != NULL))
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6877 {
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6878 incr_quickfix_busy();
12954
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6879 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
6880 (eap->cmdidx != CMD_caddexpr
95dac6af3b3a updated for version 7.0232
vimboss
parents: 789
diff changeset
6881 && 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
6882 (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
6883 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
6884 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
6885 {
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6886 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6887 goto cleanup;
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
6888 }
13062
6479dadcf214 patch 8.0.1406: difficult to track changes to a quickfix list
Christian Brabandt <cb@256bit.org>
parents: 13056
diff changeset
6889 if (res >= 0)
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
6890 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
6891
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6892 // 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
6893 // 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
6894 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
6895 if (au_name != NULL)
49e136457c66 patch 8.0.1353: QuickFixCmdPost is not used consistently
Christian Brabandt <cb@256bit.org>
parents: 12912
diff changeset
6896 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
6897 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
6898
ca6ccee4823f patch 8.1.0141: :cexpr no longer jumps to the first error
Christian Brabandt <cb@256bit.org>
parents: 14113
diff changeset
6899 // 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
6900 // free the list.
14111
678e326bf7eb patch 8.1.0073: crash when autocommands call setloclist()
Christian Brabandt <cb@256bit.org>
parents: 14085
diff changeset
6901 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
6902 || 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
6903 && qflist_valid(wp, save_qfid))
14469
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6904 // display the first error
0211e295835e patch 8.1.0248: duplicated quickfix code
Christian Brabandt <cb@256bit.org>
parents: 14433
diff changeset
6905 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
6906 decr_quickfix_busy();
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6907 }
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6908 else
626
732c7ae5743e updated for version 7.0180
vimboss
parents: 625
diff changeset
6909 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
6910 cleanup:
625
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6911 free_tv(tv);
81fe2ccc1207 updated for version 7.0179
vimboss
parents: 581
diff changeset
6912 }
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6913 }
532
7052f11a3dc9 updated for version 7.0150
vimboss
parents: 531
diff changeset
6914 #endif
446
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6915
7472c565592a updated for version 7.0117
vimboss
parents: 418
diff changeset
6916 /*
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6917 * 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
6918 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6919 static qf_info_T *
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6920 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
6921 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6922 win_T *wp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6923 qf_info_T *qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6924
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6925 // 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
6926 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
6927 wp = curwin;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6928 else
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6929 // 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
6930 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
6931
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6932 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
6933 qi = NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6934 else
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6935 qi = wp->w_llist;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6936
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6937 if (qi == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6938 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6939 // Allocate a new location list for help text matches
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6940 if ((qi = ll_new_list()) == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6941 return NULL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6942 *new_ll = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6943 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6944
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6945 return qi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6946 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6947
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6948 /*
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6949 * 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
6950 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6951 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6952 hgr_search_file(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6953 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6954 char_u *fname,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6955 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6956 vimconv_T *p_vc,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6957 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6958 regmatch_T *p_regmatch)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6959 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6960 FILE *fd;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6961 long lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6962
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6963 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
6964 if (fd == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6965 return;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6966
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6967 lnum = 1;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6968 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
6969 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6970 char_u *line = IObuff;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6971 #ifdef FEAT_MBYTE
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6972 // 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
6973 // 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
6974 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
6975 && has_non_ascii(IObuff))
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6976 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6977 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
6978 if (line == NULL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6979 line = IObuff;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6980 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6981 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6982
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6983 if (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
6984 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6985 int l = (int)STRLEN(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6986
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6987 // 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
6988 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
6989 line[--l] = NUL;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6990
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6991 if (qf_add_entry(qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6992 qi->qf_curlist,
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
6993 NULL, // dir
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6994 fname,
13821
98274127d675 patch 8.0.1782: no simple way to label quickfix entries
Christian Brabandt <cb@256bit.org>
parents: 13819
diff changeset
6995 NULL,
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6996 0,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6997 line,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6998 lnum,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
6999 (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
7000 + 1, // col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7001 FALSE, // vis_col
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7002 NULL, // search pattern
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7003 0, // nr
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7004 1, // type
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7005 TRUE // valid
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7006 ) == FAIL)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7007 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7008 got_int = TRUE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7009 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7010 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7011 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7012 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7013 break;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7014 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7015 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7016 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7017 if (line != IObuff)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7018 vim_free(line);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7019 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7020 ++lnum;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7021 line_breakcheck();
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7022 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7023 fclose(fd);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7024 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7025
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7026 /*
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7027 * 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
7028 * the given directory.
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7029 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7030 static void
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7031 hgr_search_files_in_dir(
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7032 qf_info_T *qi,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7033 char_u *dirname,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7034 regmatch_T *p_regmatch
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7035 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7036 , vimconv_T *p_vc
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7037 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7038 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7039 , char_u *lang
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7040 #endif
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 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7043 int fcount;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7044 char_u **fnames;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7045 int fi;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7046
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7047 // 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
7048 add_pathsep(dirname);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7049 STRCAT(dirname, "doc/*.\\(txt\\|??x\\)");
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7050 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
7051 &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
7052 && fcount > 0)
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 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
7055 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7056 #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
7057 // 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
7058 if (lang != NULL
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7059 && 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
7060 + 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
7061 && !(STRNICMP(lang, "en", 2) == 0
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7062 && STRNICMP("txt", fnames[fi]
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7063 + 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
7064 continue;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7065 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7066
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7067 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
7068 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7069 p_vc,
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7070 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7071 p_regmatch);
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7072 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7073 FreeWild(fcount, fnames);
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 }
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7076
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7077 /*
13868
1282a54c1f5a patch 8.0.1805: qf_parse_line() is too long
Christian Brabandt <cb@256bit.org>
parents: 13821
diff changeset
7078 * 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
7079 * 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
7080 * '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
7081 * specified language are found.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7082 */
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7083 static void
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7084 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
7085 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7086 char_u *p;
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 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7089 vimconv_T vc;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7090
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7091 // 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
7092 // differs.
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7093 vc.vc_type = CONV_NONE;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7094 if (!enc_utf8)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7095 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
7096 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7097
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7098 // 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
7099 p = p_rtp;
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7100 while (*p != NUL && !got_int)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7101 {
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7102 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
7103
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7104 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
7105 #ifdef FEAT_MBYTE
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7106 , &vc
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7107 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7108 #ifdef FEAT_MULTI_LANG
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7109 , lang
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7110 #endif
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7111 );
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
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 (vc.vc_type != CONV_NONE)
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7116 convert_setup(&vc, NULL, NULL);
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 }
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 /*
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7121 * ":helpgrep {pattern}"
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7122 */
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7123 void
7833
c079097365f3 commit https://github.com/vim/vim/commit/055409764ca5f7978d4c399d2c440af0ce971c4f
Christian Brabandt <cb@256bit.org>
parents: 7805
diff changeset
7124 ex_helpgrep(exarg_T *eap)
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7125 {
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7126 regmatch_T regmatch;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7127 char_u *save_cpo;
644
e4fa26ce8769 updated for version 7.0187
vimboss
parents: 639
diff changeset
7128 qf_info_T *qi = &ql_info;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7129 int new_qi = FALSE;
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7130 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
7131 char_u *lang = NULL;
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7132
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7133 switch (eap->cmdidx)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7134 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7135 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
7136 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
7137 default: break;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7138 }
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7139 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
7140 curbuf->b_fname, TRUE, curbuf))
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7141 {
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7142 #ifdef FEAT_EVAL
10346
d52d97bf675e commit https://github.com/vim/vim/commit/21662be2211675824df1771c7f169948ede40c41
Christian Brabandt <cb@256bit.org>
parents: 10281
diff changeset
7143 if (aborting())
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7144 return;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7145 #endif
13380
69517d67421f patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents: 13252
diff changeset
7146 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7147
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7148 // 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
7149 save_cpo = p_cpo;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7150 p_cpo = empty_option;
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7151
14550
60b9b6196644 patch 8.1.0288: quickfix code uses cmdidx too often
Christian Brabandt <cb@256bit.org>
parents: 14507
diff changeset
7152 if (is_loclist_cmd(eap->cmdidx))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7153 {
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7154 qi = hgr_get_ll(&new_qi);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7155 if (qi == NULL)
13764
7bba231fdddc patch 8.0.1754: ex_helpgrep() is too long
Christian Brabandt <cb@256bit.org>
parents: 13760
diff changeset
7156 return;
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7157 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7158
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7159 incr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7160
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7161 #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
7162 // 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
7163 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
7164 #endif
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7165 regmatch.regprog = vim_regcomp(eap->arg, RE_MAGIC + RE_STRING);
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7166 regmatch.rm_ic = FALSE;
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7167 if (regmatch.regprog != NULL)
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7168 {
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7169 qf_list_T *qfl;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7170
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7171 // 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
7172 qf_new_list(qi, qf_cmdtitle(*eap->cmdlinep));
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7173
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7174 hgr_search_in_rtp(qi, &regmatch, lang);
3257
75217982ea46 updated for version 7.3.397
Bram Moolenaar <bram@vim.org>
parents: 3242
diff changeset
7175
4805
66803af09906 updated for version 7.3.1149
Bram Moolenaar <bram@vim.org>
parents: 4371
diff changeset
7176 vim_regfree(regmatch.regprog);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7177
14915
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7178 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
7179 qfl->qf_nonevalid = FALSE;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7180 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
7181 qfl->qf_index = 1;
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7182 qf_list_changed(qfl);
f508bb2fb808 patch 8.1.0469: too often indexing in qf_lists[]
Bram Moolenaar <Bram@vim.org>
parents: 14899
diff changeset
7183 qf_update_buffer(qi, NULL);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7184 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7185
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7186 if (p_cpo == empty_option)
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7187 p_cpo = save_cpo;
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7188 else
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7189 // Darn, some plugin changed the value.
1672
fddea6c03dee updated for version 7.2b-004
vimboss
parents: 1668
diff changeset
7190 free_string_option(save_cpo);
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7191
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7192 if (au_name != NULL)
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7193 {
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7194 apply_autocmds(EVENT_QUICKFIXCMDPOST, au_name,
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7195 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
7196 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
7197 {
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7198 // 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
7199 decr_quickfix_busy();
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7200 return;
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7201 }
3269
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7202 }
5850b5827691 updated for version 7.3.403
Bram Moolenaar <bram@vim.org>
parents: 3267
diff changeset
7203
14899
e35d98651e56 patch 8.1.0461: quickfix code uses too many /* */ comments
Bram Moolenaar <Bram@vim.org>
parents: 14887
diff changeset
7204 // Jump to first match.
14477
1ccf5dcd88ca patch 8.1.0252: quickfix functions are too long
Christian Brabandt <cb@256bit.org>
parents: 14469
diff changeset
7205 if (!qf_list_empty(qi, qi->qf_curlist))
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7206 qf_jump(qi, 0, 0, FALSE);
9
4102fb4ea781 updated for version 7.0002
vimboss
parents: 7
diff changeset
7207 else
4102fb4ea781 updated for version 7.0002
vimboss
parents: 7
diff changeset
7208 EMSG2(_(e_nomatch2), eap->arg);
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7209
14954
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7210 decr_quickfix_busy();
69d2749a6a2f patch 8.1.0488: using freed memory in quickfix code
Bram Moolenaar <Bram@vim.org>
parents: 14915
diff changeset
7211
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7212 if (eap->cmdidx == CMD_lhelpgrep)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7213 {
14603
d1b69129db99 patch 8.1.0315: helpgrep with language doesn't work properly
Christian Brabandt <cb@256bit.org>
parents: 14560
diff changeset
7214 // 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
7215 // 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
7216 if (!bt_help(curwin->w_buffer) || curwin->w_llist == qi)
659
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7217 {
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7218 if (new_qi)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7219 ll_free_all(&qi);
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7220 }
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7221 else if (curwin->w_llist == NULL)
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7222 curwin->w_llist = qi;
d6a69271cb9a updated for version 7.0194
vimboss
parents: 657
diff changeset
7223 }
7
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7224 }
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7225
3fc0f57ecb91 updated for version 7.0001
vimboss
parents:
diff changeset
7226 #endif /* FEAT_QUICKFIX */