fmt_decl.c revision 1.38 1 1.38 rillig /* $NetBSD: fmt_decl.c,v 1.38 2023/05/13 06:52:48 rillig Exp $ */
2 1.1 rillig
3 1.19 rillig /*
4 1.19 rillig * Tests for declarations of global variables, external functions, and local
5 1.19 rillig * variables.
6 1.19 rillig *
7 1.19 rillig * See also:
8 1.19 rillig * opt_di.c
9 1.19 rillig */
10 1.19 rillig
11 1.1 rillig /* See FreeBSD r303570 */
12 1.1 rillig
13 1.19 rillig /*
14 1.19 rillig * A type definition usually declares a single type, so there is no need to
15 1.19 rillig * align the newly declared type name with the other variables.
16 1.19 rillig */
17 1.35 rillig //indent input
18 1.30 rillig typedef void ( * function_ptr ) ( int * ) ;
19 1.35 rillig //indent end
20 1.1 rillig
21 1.35 rillig //indent run
22 1.30 rillig typedef void (*function_ptr)(int *);
23 1.35 rillig //indent end
24 1.1 rillig
25 1.1 rillig
26 1.19 rillig /*
27 1.19 rillig * In variable declarations, the names of the first declarators are indented
28 1.19 rillig * by the amount given in '-di', which defaults to 16.
29 1.19 rillig */
30 1.35 rillig //indent input
31 1.19 rillig extern void ( * function_pointer ) ( int * ) ;
32 1.19 rillig extern void * pointer;
33 1.35 rillig //indent end
34 1.19 rillig
35 1.35 rillig //indent run
36 1.19 rillig /* $ XXX: Why is the token 'function_pointer' not aligned with 'pointer'? */
37 1.19 rillig extern void (*function_pointer)(int *);
38 1.19 rillig extern void *pointer;
39 1.35 rillig //indent end
40 1.19 rillig
41 1.19 rillig
42 1.35 rillig //indent input
43 1.1 rillig static const struct
44 1.1 rillig {
45 1.1 rillig double x;
46 1.1 rillig double y, z;
47 1.1 rillig } n[m + 1] =
48 1.1 rillig {
49 1.1 rillig {
50 1.1 rillig .0,
51 1.1 rillig .9,
52 1.1 rillig 5
53 1.1 rillig }
54 1.1 rillig };
55 1.35 rillig //indent end
56 1.1 rillig
57 1.35 rillig //indent run
58 1.37 rillig static const struct
59 1.37 rillig {
60 1.1 rillig double x;
61 1.1 rillig double y, z;
62 1.1 rillig } n[m + 1] =
63 1.1 rillig {
64 1.1 rillig {
65 1.1 rillig .0,
66 1.1 rillig .9,
67 1.1 rillig 5
68 1.1 rillig }
69 1.1 rillig };
70 1.35 rillig //indent end
71 1.1 rillig
72 1.1 rillig
73 1.35 rillig //indent input
74 1.1 rillig typedef struct Complex
75 1.1 rillig {
76 1.1 rillig double x;
77 1.1 rillig double y;
78 1.1 rillig } Complex;
79 1.35 rillig //indent end
80 1.1 rillig
81 1.35 rillig //indent run
82 1.37 rillig typedef struct Complex
83 1.37 rillig {
84 1.1 rillig double x;
85 1.1 rillig double y;
86 1.1 rillig } Complex;
87 1.35 rillig //indent end
88 1.1 rillig
89 1.1 rillig
90 1.8 rillig /*
91 1.38 rillig * Ensure that function definitions are reasonably indented. Before
92 1.38 rillig * 2023-05-11, tokens were repeatedly read, and the line numbers were wrong.
93 1.8 rillig */
94 1.35 rillig //indent input
95 1.1 rillig void
96 1.1 rillig t1 (char *a, int b,
97 1.1 rillig void (*fn)(void))
98 1.1 rillig {}
99 1.35 rillig //indent end
100 1.1 rillig
101 1.35 rillig //indent run
102 1.1 rillig void
103 1.1 rillig t1(char *a, int b,
104 1.1 rillig void (*fn)(void))
105 1.1 rillig {
106 1.1 rillig }
107 1.35 rillig //indent end
108 1.1 rillig
109 1.1 rillig
110 1.19 rillig /* See opt_bc.c. */
111 1.35 rillig //indent input
112 1.1 rillig void t2 (char *x, int y)
113 1.1 rillig {
114 1.1 rillig int a,
115 1.1 rillig b,
116 1.1 rillig c;
117 1.1 rillig int
118 1.1 rillig *d,
119 1.1 rillig *e,
120 1.1 rillig *f;
121 1.1 rillig int (*g)(),
122 1.1 rillig (*h)(),
123 1.1 rillig (*i)();
124 1.1 rillig int j,
125 1.1 rillig k,
126 1.1 rillig l;
127 1.1 rillig int m
128 1.1 rillig ,n
129 1.1 rillig ,o
130 1.1 rillig ;
131 1.1 rillig int chars[ /* push the comma beyond column 74 .... */ ], x;
132 1.1 rillig }
133 1.35 rillig //indent end
134 1.1 rillig
135 1.35 rillig //indent run
136 1.1 rillig void
137 1.1 rillig t2(char *x, int y)
138 1.1 rillig {
139 1.1 rillig int a, b, c;
140 1.1 rillig int
141 1.1 rillig *d, *e, *f;
142 1.1 rillig int (*g)(), (*h)(), (*i)();
143 1.1 rillig int j, k, l;
144 1.1 rillig int m
145 1.1 rillig ,n
146 1.1 rillig ,o
147 1.1 rillig ;
148 1.1 rillig int chars[ /* push the comma beyond column 74 .... */ ],
149 1.1 rillig x;
150 1.1 rillig }
151 1.35 rillig //indent end
152 1.1 rillig
153 1.1 rillig
154 1.35 rillig //indent input
155 1.1 rillig const int int_minimum_size =
156 1.1 rillig MAXALIGN(offsetof(int, test)) + MAXIMUM_ALIGNOF;
157 1.35 rillig //indent end
158 1.1 rillig
159 1.35 rillig //indent run-equals-input
160 1.1 rillig
161 1.1 rillig
162 1.25 rillig /*
163 1.25 rillig * Ensure that the usual GCC-style function attributes are formatted in a
164 1.25 rillig * sensible way.
165 1.25 rillig */
166 1.35 rillig //indent input
167 1.25 rillig void function(const char *, ...) __attribute__((format(printf, 1, 2)));
168 1.35 rillig //indent end
169 1.25 rillig
170 1.25 rillig /* FIXME: missing space before '__attribute__' */
171 1.35 rillig //indent run -di0
172 1.25 rillig void function(const char *, ...)__attribute__((format(printf, 1, 2)));
173 1.35 rillig //indent end
174 1.25 rillig
175 1.25 rillig /* FIXME: missing space before '__attribute__' */
176 1.35 rillig //indent run
177 1.25 rillig void function(const char *, ...)__attribute__((format(printf, 1, 2)));
178 1.35 rillig //indent end
179 1.25 rillig
180 1.25 rillig
181 1.35 rillig //indent input
182 1.1 rillig static
183 1.1 rillig _attribute_printf(1, 2)
184 1.1 rillig void
185 1.1 rillig print_error(const char *fmt,...)
186 1.1 rillig {
187 1.1 rillig }
188 1.35 rillig //indent end
189 1.1 rillig
190 1.35 rillig //indent run
191 1.1 rillig static
192 1.1 rillig _attribute_printf(1, 2)
193 1.1 rillig void
194 1.1 rillig print_error(const char *fmt, ...)
195 1.1 rillig {
196 1.2 rillig }
197 1.35 rillig //indent end
198 1.2 rillig
199 1.2 rillig
200 1.35 rillig //indent input
201 1.2 rillig static _attribute_printf(1, 2)
202 1.2 rillig void
203 1.2 rillig print_error(const char *fmt,...)
204 1.2 rillig {
205 1.2 rillig }
206 1.35 rillig //indent end
207 1.1 rillig
208 1.35 rillig //indent run
209 1.2 rillig static _attribute_printf(1, 2)
210 1.2 rillig void
211 1.2 rillig print_error(const char *fmt, ...)
212 1.2 rillig {
213 1.2 rillig }
214 1.35 rillig //indent end
215 1.2 rillig
216 1.2 rillig
217 1.35 rillig //indent input
218 1.2 rillig static void _attribute_printf(1, 2)
219 1.2 rillig print_error(const char *fmt,...)
220 1.2 rillig {
221 1.2 rillig }
222 1.35 rillig //indent end
223 1.2 rillig
224 1.35 rillig //indent run
225 1.2 rillig static void
226 1.2 rillig _attribute_printf(1, 2)
227 1.2 rillig print_error(const char *fmt, ...)
228 1.2 rillig {
229 1.1 rillig }
230 1.35 rillig //indent end
231 1.1 rillig
232 1.1 rillig
233 1.3 rillig /* See FreeBSD r309380 */
234 1.35 rillig //indent input
235 1.1 rillig static LIST_HEAD(, alq) ald_active;
236 1.19 rillig static int ald_shutting_down = 0;
237 1.1 rillig struct thread *ald_thread;
238 1.35 rillig //indent end
239 1.1 rillig
240 1.35 rillig //indent run
241 1.1 rillig static LIST_HEAD(, alq) ald_active;
242 1.19 rillig static int ald_shutting_down = 0;
243 1.1 rillig struct thread *ald_thread;
244 1.35 rillig //indent end
245 1.1 rillig
246 1.1 rillig
247 1.35 rillig //indent input
248 1.1 rillig static int
249 1.2 rillig old_style_definition(a, b, c)
250 1.2 rillig struct thread *a;
251 1.2 rillig int b;
252 1.2 rillig double ***c;
253 1.1 rillig {
254 1.1 rillig
255 1.1 rillig }
256 1.35 rillig //indent end
257 1.1 rillig
258 1.35 rillig //indent run
259 1.1 rillig static int
260 1.2 rillig old_style_definition(a, b, c)
261 1.2 rillig struct thread *a;
262 1.2 rillig int b;
263 1.2 rillig double ***c;
264 1.1 rillig {
265 1.1 rillig
266 1.1 rillig }
267 1.35 rillig //indent end
268 1.1 rillig
269 1.1 rillig
270 1.1 rillig /*
271 1.1 rillig * Demonstrate how variable declarations are broken into several lines when
272 1.1 rillig * the line length limit is set quite low.
273 1.1 rillig */
274 1.35 rillig //indent input
275 1.7 rillig struct s a,b;
276 1.1 rillig struct s0 a,b;
277 1.1 rillig struct s01 a,b;
278 1.1 rillig struct s012 a,b;
279 1.1 rillig struct s0123 a,b;
280 1.1 rillig struct s01234 a,b;
281 1.1 rillig struct s012345 a,b;
282 1.1 rillig struct s0123456 a,b;
283 1.1 rillig struct s01234567 a,b;
284 1.1 rillig struct s012345678 a,b;
285 1.1 rillig struct s0123456789 a,b;
286 1.1 rillig struct s01234567890 a,b;
287 1.1 rillig struct s012345678901 a,b;
288 1.1 rillig struct s0123456789012 a,b;
289 1.1 rillig struct s01234567890123 a,b;
290 1.35 rillig //indent end
291 1.1 rillig
292 1.35 rillig //indent run -l20 -di0
293 1.7 rillig struct s a, b;
294 1.7 rillig /* $ XXX: See process_comma, varname_len for why this line is broken. */
295 1.1 rillig struct s0 a,
296 1.1 rillig b;
297 1.7 rillig /* $ XXX: The indentation of the second line is wrong. The variable names */
298 1.7 rillig /* $ XXX: 'a' and 'b' should be in the same column; the word 'struct' is */
299 1.7 rillig /* $ XXX: missing in the calculation for the indentation. */
300 1.1 rillig struct s01 a,
301 1.1 rillig b;
302 1.1 rillig struct s012 a,
303 1.1 rillig b;
304 1.1 rillig struct s0123 a,
305 1.1 rillig b;
306 1.1 rillig struct s01234 a,
307 1.1 rillig b;
308 1.1 rillig struct s012345 a,
309 1.1 rillig b;
310 1.1 rillig struct s0123456 a,
311 1.1 rillig b;
312 1.1 rillig struct s01234567 a,
313 1.1 rillig b;
314 1.1 rillig struct s012345678 a,
315 1.1 rillig b;
316 1.1 rillig struct s0123456789 a,
317 1.1 rillig b;
318 1.1 rillig struct s01234567890 a,
319 1.1 rillig b;
320 1.1 rillig struct s012345678901 a,
321 1.1 rillig b;
322 1.1 rillig struct s0123456789012 a,
323 1.1 rillig b;
324 1.1 rillig struct s01234567890123 a,
325 1.1 rillig b;
326 1.35 rillig //indent end
327 1.2 rillig
328 1.2 rillig
329 1.35 rillig //indent input
330 1.2 rillig char * x(void)
331 1.2 rillig {
332 1.2 rillig type identifier;
333 1.2 rillig type *pointer;
334 1.2 rillig unused * value;
335 1.2 rillig (void)unused * value;
336 1.2 rillig
337 1.2 rillig dmax = (double)3 * 10.0;
338 1.2 rillig dmin = (double)dmax * 10.0;
339 1.2 rillig davg = (double)dmax * dmin;
340 1.2 rillig
341 1.2 rillig return NULL;
342 1.2 rillig }
343 1.35 rillig //indent end
344 1.2 rillig
345 1.35 rillig //indent run
346 1.2 rillig char *
347 1.2 rillig x(void)
348 1.2 rillig {
349 1.2 rillig type identifier;
350 1.2 rillig type *pointer;
351 1.2 rillig unused *value;
352 1.2 rillig (void)unused * value;
353 1.2 rillig
354 1.2 rillig dmax = (double)3 * 10.0;
355 1.2 rillig dmin = (double)dmax * 10.0;
356 1.2 rillig davg = (double)dmax * dmin;
357 1.2 rillig
358 1.2 rillig return NULL;
359 1.2 rillig }
360 1.35 rillig //indent end
361 1.2 rillig
362 1.21 rillig
363 1.35 rillig //indent input
364 1.2 rillig int *
365 1.2 rillig y(void) {
366 1.2 rillig
367 1.2 rillig }
368 1.2 rillig
369 1.2 rillig int
370 1.2 rillig z(void) {
371 1.2 rillig
372 1.2 rillig }
373 1.35 rillig //indent end
374 1.2 rillig
375 1.35 rillig //indent run
376 1.2 rillig int *
377 1.2 rillig y(void)
378 1.2 rillig {
379 1.2 rillig
380 1.2 rillig }
381 1.2 rillig
382 1.2 rillig int
383 1.2 rillig z(void)
384 1.2 rillig {
385 1.2 rillig
386 1.2 rillig }
387 1.35 rillig //indent end
388 1.2 rillig
389 1.2 rillig
390 1.35 rillig //indent input
391 1.2 rillig int x;
392 1.2 rillig int *y;
393 1.2 rillig int * * * * z;
394 1.35 rillig //indent end
395 1.2 rillig
396 1.35 rillig //indent run
397 1.2 rillig int x;
398 1.2 rillig int *y;
399 1.2 rillig int ****z;
400 1.35 rillig //indent end
401 1.4 rillig
402 1.4 rillig
403 1.35 rillig //indent input
404 1.4 rillig int main(void) {
405 1.4 rillig char (*f1)() = NULL;
406 1.4 rillig char *(*f1)() = NULL;
407 1.4 rillig char *(*f2)();
408 1.4 rillig }
409 1.35 rillig //indent end
410 1.4 rillig
411 1.6 rillig /*
412 1.6 rillig * Before NetBSD io.c 1.103 from 2021-10-27, indent wrongly placed the second
413 1.6 rillig * and third variable declaration in column 1. This bug has been introduced
414 1.6 rillig * to NetBSD when FreeBSD indent was imported in 2019.
415 1.6 rillig */
416 1.35 rillig //indent run -ldi0
417 1.4 rillig int
418 1.4 rillig main(void)
419 1.4 rillig {
420 1.4 rillig char (*f1)() = NULL;
421 1.6 rillig char *(*f1)() = NULL;
422 1.6 rillig char *(*f2)();
423 1.4 rillig }
424 1.35 rillig //indent end
425 1.5 rillig
426 1.35 rillig //indent run
427 1.5 rillig int
428 1.5 rillig main(void)
429 1.5 rillig {
430 1.5 rillig /* $ XXX: Not really pretty, the name 'f1' should be aligned, if at all. */
431 1.5 rillig char (*f1)() = NULL;
432 1.5 rillig /* $ XXX: Not really pretty, the name 'f1' should be aligned, if at all. */
433 1.6 rillig char *(* f1)() = NULL;
434 1.5 rillig /* $ XXX: Not really pretty, the name 'f2' should be aligned, if at all. */
435 1.6 rillig char *(* f2)();
436 1.5 rillig }
437 1.35 rillig //indent end
438 1.10 rillig
439 1.10 rillig
440 1.10 rillig /*
441 1.10 rillig * In some ancient time long before ISO C90, variable declarations with
442 1.10 rillig * initializer could be written without '='. The C Programming Language from
443 1.10 rillig * 1978 doesn't mention this form anymore.
444 1.18 rillig *
445 1.18 rillig * Before NetBSD lexi.c 1.123 from 2021-10-31, indent treated the '-' as a
446 1.18 rillig * unary operator.
447 1.10 rillig */
448 1.35 rillig //indent input
449 1.10 rillig int a - 1;
450 1.10 rillig {
451 1.10 rillig int a - 1;
452 1.10 rillig }
453 1.35 rillig //indent end
454 1.10 rillig
455 1.35 rillig //indent run -di0
456 1.11 rillig int a - 1;
457 1.10 rillig {
458 1.11 rillig int a - 1;
459 1.10 rillig }
460 1.35 rillig //indent end
461 1.14 rillig
462 1.14 rillig
463 1.14 rillig /*
464 1.20 rillig * Between 2019-04-04 and before lexi.c 1.146 from 2021-11-19, the indentation
465 1.18 rillig * of the '*' depended on the function name, which did not make sense. For
466 1.18 rillig * function names that matched [A-Za-z]+, the '*' was placed correctly, for
467 1.18 rillig * all other function names (containing [$0-9_]) the '*' was right-aligned on
468 1.20 rillig * the declaration indentation, which defaults to 16.
469 1.14 rillig */
470 1.35 rillig //indent input
471 1.14 rillig int *
472 1.14 rillig f2(void)
473 1.14 rillig {
474 1.14 rillig }
475 1.14 rillig
476 1.14 rillig int *
477 1.14 rillig yy(void)
478 1.14 rillig {
479 1.14 rillig }
480 1.14 rillig
481 1.14 rillig int *
482 1.18 rillig int_create(void)
483 1.14 rillig {
484 1.14 rillig }
485 1.35 rillig //indent end
486 1.15 rillig
487 1.35 rillig //indent run-equals-input
488 1.18 rillig
489 1.15 rillig
490 1.15 rillig /*
491 1.15 rillig * Since 2019-04-04, the space between the '){' is missing.
492 1.15 rillig */
493 1.35 rillig //indent input
494 1.15 rillig int *
495 1.15 rillig function_name_____20________30________40________50
496 1.15 rillig (void)
497 1.15 rillig {}
498 1.35 rillig //indent end
499 1.15 rillig
500 1.38 rillig /*
501 1.38 rillig * Before 2023-05-11, indent moved the '{' right after the '(void)', without
502 1.38 rillig * any space in between.
503 1.38 rillig */
504 1.35 rillig //indent run
505 1.15 rillig int *function_name_____20________30________40________50
506 1.37 rillig (void)
507 1.37 rillig {
508 1.15 rillig }
509 1.35 rillig //indent end
510 1.15 rillig
511 1.15 rillig
512 1.15 rillig /*
513 1.17 rillig * Since 2019-04-04 and before lexi.c 1.144 from 2021-11-19, some function
514 1.17 rillig * names were preserved while others were silently discarded.
515 1.15 rillig */
516 1.35 rillig //indent input
517 1.15 rillig int *
518 1.15 rillig aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
519 1.15 rillig (void)
520 1.15 rillig {}
521 1.35 rillig //indent end
522 1.15 rillig
523 1.38 rillig /*
524 1.38 rillig * Before 2023-05-11, indent moved the '{' right after the '(void)', without
525 1.38 rillig * any space in between.
526 1.38 rillig */
527 1.35 rillig //indent run
528 1.16 rillig int *aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
529 1.37 rillig (void)
530 1.37 rillig {
531 1.15 rillig }
532 1.35 rillig //indent end
533 1.22 rillig
534 1.22 rillig
535 1.22 rillig /*
536 1.22 rillig * Before 1990, when C90 standardized function prototypes, a function
537 1.22 rillig * declaration or definition did not contain a '*' that may have looked
538 1.22 rillig * similar to the binary operator '*' because it was surrounded by two
539 1.22 rillig * identifiers.
540 1.22 rillig *
541 1.26 rillig * As of 2021-11-21, indent interpreted the '*' in the function declaration in
542 1.26 rillig * line 1 as a binary operator, even though the '*' was followed by a ','
543 1.26 rillig * directly. This was not visible in the output though since indent never
544 1.26 rillig * outputs a space before a comma.
545 1.22 rillig *
546 1.26 rillig * In the function declaration in line 2 and the function definition in line
547 1.26 rillig * 5, indent interpreted the '*' as a binary operator as well and accordingly
548 1.26 rillig * placed spaces around the '*'. On a very low syntactical analysis level,
549 1.26 rillig * this may have made sense since the '*' was surrounded by words, but still
550 1.26 rillig * the '*' is part of a declaration, where a binary operator does not make
551 1.26 rillig * sense.
552 1.26 rillig *
553 1.26 rillig * Essentially, as of 2021, indent had missed the last 31 years of advances in
554 1.26 rillig * the C programming language, in particular the invention of function
555 1.26 rillig * prototypes. Instead, the workaround had been to require all type names to
556 1.26 rillig * be specified via the options '-ta' and '-T'. This put the burden on the
557 1.26 rillig * user instead of the implementer.
558 1.26 rillig *
559 1.26 rillig * Fixed in lexi.c 1.156 from 2021-11-25.
560 1.22 rillig */
561 1.35 rillig //indent input
562 1.22 rillig void buffer_add(buffer *, char);
563 1.22 rillig void buffer_add(buffer *buf, char ch);
564 1.22 rillig
565 1.22 rillig void
566 1.22 rillig buffer_add(buffer *buf, char ch)
567 1.22 rillig {
568 1.22 rillig *buf->e++ = ch;
569 1.22 rillig }
570 1.35 rillig //indent end
571 1.22 rillig
572 1.26 rillig /* Before lexi.c 1.156 from 2021-11-25, indent generated 'buffer * buf'. */
573 1.35 rillig //indent run
574 1.29 rillig void buffer_add(buffer *, char);
575 1.29 rillig /* $ FIXME: space after '*' */
576 1.29 rillig void buffer_add(buffer * buf, char ch);
577 1.29 rillig
578 1.29 rillig void
579 1.29 rillig buffer_add(buffer *buf, char ch)
580 1.29 rillig {
581 1.29 rillig *buf->e++ = ch;
582 1.29 rillig }
583 1.35 rillig //indent end
584 1.23 rillig
585 1.23 rillig
586 1.23 rillig /*
587 1.38 rillig * Before lexi.c 1.153 from 2021-11-25, indent did not recognize 'Token' as a
588 1.38 rillig * type name and then messed up the positioning of the '{'.
589 1.23 rillig */
590 1.35 rillig //indent input
591 1.23 rillig static Token
592 1.23 rillig ToToken(bool cond)
593 1.23 rillig {
594 1.23 rillig }
595 1.35 rillig //indent end
596 1.23 rillig
597 1.35 rillig //indent run-equals-input -TToken
598 1.34 rillig
599 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
600 1.35 rillig //indent run-equals-input
601 1.23 rillig
602 1.23 rillig
603 1.23 rillig /*
604 1.23 rillig * Indent gets easily confused by unknown type names in struct declarations.
605 1.23 rillig */
606 1.35 rillig //indent input
607 1.23 rillig typedef struct OpenDirs {
608 1.23 rillig CachedDirList list;
609 1.23 rillig HashTable /* of CachedDirListNode */ table;
610 1.23 rillig } OpenDirs;
611 1.35 rillig //indent end
612 1.23 rillig
613 1.23 rillig /* FIXME: The word 'HashTable' must not be aligned like a member name. */
614 1.35 rillig //indent run
615 1.23 rillig typedef struct OpenDirs {
616 1.23 rillig CachedDirList list;
617 1.23 rillig HashTable /* of CachedDirListNode */ table;
618 1.23 rillig } OpenDirs;
619 1.35 rillig //indent end
620 1.23 rillig
621 1.35 rillig //indent run-equals-input -THashTable
622 1.23 rillig
623 1.23 rillig
624 1.23 rillig /*
625 1.23 rillig * Indent gets easily confused by unknown type names, even in declarations
626 1.23 rillig * that are syntactically unambiguous.
627 1.23 rillig */
628 1.35 rillig //indent input
629 1.23 rillig static CachedDir *dot = NULL;
630 1.35 rillig //indent end
631 1.23 rillig
632 1.35 rillig //indent run-equals-input -TCachedDir
633 1.34 rillig
634 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
635 1.35 rillig //indent run-equals-input
636 1.23 rillig
637 1.23 rillig
638 1.23 rillig /*
639 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent easily got confused by unknown
640 1.26 rillig * type names in declarations and generated 'HashEntry * he' with an extra
641 1.26 rillig * space.
642 1.23 rillig */
643 1.35 rillig //indent input
644 1.23 rillig static CachedDir *
645 1.23 rillig CachedDir_New(const char *name)
646 1.23 rillig {
647 1.23 rillig }
648 1.35 rillig //indent end
649 1.23 rillig
650 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
651 1.35 rillig //indent run-equals-input
652 1.23 rillig
653 1.23 rillig
654 1.23 rillig /*
655 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent easily got confused by unknown
656 1.26 rillig * type names in declarations and generated 'CachedDir * dir' with an extra
657 1.26 rillig * space.
658 1.23 rillig */
659 1.35 rillig //indent input
660 1.23 rillig static CachedDir *
661 1.23 rillig CachedDir_Ref(CachedDir *dir)
662 1.23 rillig {
663 1.23 rillig }
664 1.35 rillig //indent end
665 1.23 rillig
666 1.35 rillig //indent run-equals-input
667 1.23 rillig
668 1.23 rillig
669 1.23 rillig /*
670 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent easily got confused by unknown
671 1.26 rillig * type names in declarations and generated 'HashEntry * he' with an extra
672 1.26 rillig * space.
673 1.26 rillig *
674 1.26 rillig * Before lexi.c 1.153 from 2021-11-25, indent also placed the '{' at the end
675 1.26 rillig * of the line.
676 1.23 rillig */
677 1.35 rillig //indent input
678 1.23 rillig static bool
679 1.23 rillig HashEntry_KeyEquals(const HashEntry *he, Substring key)
680 1.23 rillig {
681 1.23 rillig }
682 1.35 rillig //indent end
683 1.23 rillig
684 1.35 rillig //indent run-equals-input
685 1.23 rillig
686 1.23 rillig
687 1.23 rillig /*
688 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent didn't notice that the two '*'
689 1.26 rillig * are in a declaration, instead it interpreted the first '*' as a binary
690 1.26 rillig * operator, therefore generating 'CachedDir * *var' with an extra space.
691 1.23 rillig */
692 1.35 rillig //indent input
693 1.23 rillig static void
694 1.23 rillig CachedDir_Assign(CachedDir **var, CachedDir *dir)
695 1.23 rillig {
696 1.23 rillig }
697 1.35 rillig //indent end
698 1.23 rillig
699 1.35 rillig //indent run-equals-input
700 1.34 rillig
701 1.35 rillig //indent run-equals-input -TCachedDir
702 1.23 rillig
703 1.23 rillig
704 1.23 rillig /*
705 1.24 rillig * Before lexi.c 1.153 from 2021-11-25, all initializer expressions after the
706 1.24 rillig * first one were indented as if they would be statement continuations. This
707 1.24 rillig * was because the token 'Shell' was identified as a word, not as a type name.
708 1.23 rillig */
709 1.35 rillig //indent input
710 1.24 rillig static Shell shells[] = {
711 1.23 rillig {
712 1.23 rillig first,
713 1.23 rillig second,
714 1.23 rillig },
715 1.23 rillig };
716 1.35 rillig //indent end
717 1.23 rillig
718 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
719 1.35 rillig //indent run-equals-input
720 1.23 rillig
721 1.23 rillig
722 1.23 rillig /*
723 1.27 rillig * Before lexi.c 1.158 from 2021-11-25, indent easily got confused by function
724 1.27 rillig * attribute macros that followed the function declaration. Its primitive
725 1.27 rillig * heuristic between deciding between a function declaration and a function
726 1.27 rillig * definition only looked for ')' immediately followed by ',' or ';'. This was
727 1.27 rillig * sufficient for well-formatted code before 1990. With the addition of
728 1.27 rillig * function prototypes and GCC attributes, the situation became more
729 1.27 rillig * complicated, and it took indent 31 years to adapt to this new reality.
730 1.23 rillig */
731 1.35 rillig //indent input
732 1.23 rillig static void JobInterrupt(bool, int) MAKE_ATTR_DEAD;
733 1.23 rillig static void JobRestartJobs(void);
734 1.35 rillig //indent end
735 1.23 rillig
736 1.35 rillig //indent run
737 1.23 rillig /* $ FIXME: Missing space before 'MAKE_ATTR_DEAD'. */
738 1.27 rillig static void JobInterrupt(bool, int)MAKE_ATTR_DEAD;
739 1.27 rillig static void JobRestartJobs(void);
740 1.35 rillig //indent end
741 1.23 rillig
742 1.23 rillig
743 1.23 rillig /*
744 1.27 rillig * Before lexi.c 1.158 from 2021-11-25, indent easily got confused by the
745 1.27 rillig * tokens ')' and ';' in the function body. It wrongly regarded them as
746 1.27 rillig * finishing a function declaration.
747 1.23 rillig */
748 1.35 rillig //indent input
749 1.23 rillig MAKE_INLINE const char *
750 1.23 rillig GNode_VarTarget(GNode *gn) { return GNode_ValueDirect(gn, TARGET); }
751 1.35 rillig //indent end
752 1.23 rillig
753 1.26 rillig /*
754 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent generated 'GNode * gn' with an
755 1.26 rillig * extra space.
756 1.27 rillig *
757 1.27 rillig * Before lexi.c 1.158 from 2021-11-25, indent wrongly placed the function
758 1.27 rillig * name in line 1, together with the '{'.
759 1.26 rillig */
760 1.35 rillig //indent run
761 1.27 rillig MAKE_INLINE const char *
762 1.27 rillig GNode_VarTarget(GNode *gn)
763 1.27 rillig {
764 1.23 rillig return GNode_ValueDirect(gn, TARGET);
765 1.23 rillig }
766 1.35 rillig //indent end
767 1.23 rillig
768 1.35 rillig //indent run-equals-prev-output -TGNode
769 1.25 rillig
770 1.25 rillig
771 1.25 rillig /*
772 1.25 rillig * Ensure that '*' in declarations is interpreted (or at least formatted) as
773 1.25 rillig * a 'pointer to' type derivation, not as a binary or unary operator.
774 1.25 rillig */
775 1.35 rillig //indent input
776 1.25 rillig number *var = a * b;
777 1.25 rillig
778 1.25 rillig void
779 1.25 rillig function(void)
780 1.25 rillig {
781 1.25 rillig number *var = a * b;
782 1.25 rillig }
783 1.35 rillig //indent end
784 1.25 rillig
785 1.35 rillig //indent run-equals-input -di0
786 1.28 rillig
787 1.28 rillig
788 1.28 rillig /*
789 1.28 rillig * In declarations, most occurrences of '*' are pointer type derivations.
790 1.29 rillig * There are a few exceptions though. Some of these are hard to detect
791 1.29 rillig * without knowing which identifiers are type names.
792 1.28 rillig */
793 1.35 rillig //indent input
794 1.28 rillig char str[expr * expr];
795 1.28 rillig char str[expr**ptr];
796 1.28 rillig char str[*ptr**ptr];
797 1.28 rillig char str[sizeof(expr * expr)];
798 1.28 rillig char str[sizeof(int) * expr];
799 1.28 rillig char str[sizeof(*ptr)];
800 1.28 rillig char str[sizeof(type**)];
801 1.28 rillig char str[sizeof(**ptr)];
802 1.35 rillig //indent end
803 1.28 rillig
804 1.35 rillig //indent run -di0
805 1.29 rillig char str[expr * expr];
806 1.29 rillig char str[expr * *ptr];
807 1.29 rillig char str[*ptr * *ptr];
808 1.29 rillig char str[sizeof(expr * expr)];
809 1.29 rillig char str[sizeof(int) * expr];
810 1.28 rillig char str[sizeof(*ptr)];
811 1.29 rillig /* $ FIXME: should be 'type **' */
812 1.29 rillig char str[sizeof(type * *)];
813 1.28 rillig char str[sizeof(**ptr)];
814 1.35 rillig //indent end
815 1.31 rillig
816 1.31 rillig
817 1.31 rillig /*
818 1.32 rillig * Since lexi.c 1.158 from 2021-11-25, whether the function 'a' was considered
819 1.32 rillig * a declaration or a definition depended on the preceding struct, in
820 1.32 rillig * particular the length of the 'pn' line. This didn't make sense at all and
821 1.32 rillig * was due to an out-of-bounds memory access.
822 1.31 rillig *
823 1.31 rillig * Seen amongst others in args.c 1.72, function add_typedefs_from_file.
824 1.32 rillig * Fixed in lexi.c 1.165 from 2021-11-27.
825 1.31 rillig */
826 1.35 rillig //indent input
827 1.31 rillig struct {
828 1.31 rillig } v = {
829 1.31 rillig pn("ta"),
830 1.31 rillig };
831 1.31 rillig
832 1.31 rillig static void
833 1.31 rillig a(char *fe)
834 1.31 rillig {
835 1.31 rillig }
836 1.31 rillig
837 1.31 rillig struct {
838 1.31 rillig } v = {
839 1.31 rillig pn("t"),
840 1.31 rillig };
841 1.31 rillig
842 1.31 rillig static void
843 1.31 rillig a(char *fe)
844 1.31 rillig {
845 1.31 rillig }
846 1.35 rillig //indent end
847 1.31 rillig
848 1.35 rillig //indent run -di0
849 1.31 rillig struct {
850 1.31 rillig } v = {
851 1.31 rillig pn("ta"),
852 1.31 rillig };
853 1.31 rillig
854 1.31 rillig static void
855 1.32 rillig a(char *fe)
856 1.32 rillig {
857 1.31 rillig }
858 1.31 rillig
859 1.31 rillig struct {
860 1.31 rillig } v = {
861 1.31 rillig pn("t"),
862 1.31 rillig };
863 1.31 rillig
864 1.31 rillig static void
865 1.31 rillig a(char *fe)
866 1.31 rillig {
867 1.31 rillig }
868 1.35 rillig //indent end
869 1.36 rillig
870 1.36 rillig
871 1.36 rillig /*
872 1.36 rillig * Before NetBSD indent.c 1.178 from 2021-10-29, indent removed the blank
873 1.36 rillig * before the '=', in the second and third of these function pointer
874 1.36 rillig * declarations. This was because indent interpreted the prototype parameters
875 1.36 rillig * 'int' and 'int, int' as type casts, which doesn't make sense at all. Fixing
876 1.36 rillig * this properly requires large style changes since indent is based on simple
877 1.36 rillig * heuristics all over. This didn't change in indent.c 1.178; instead, the
878 1.36 rillig * rule for inserting a blank before a binary operator was changed to always
879 1.36 rillig * insert a blank, except at the beginning of a line.
880 1.36 rillig */
881 1.36 rillig //indent input
882 1.36 rillig char *(*fn)() = NULL;
883 1.36 rillig char *(*fn)(int) = NULL;
884 1.36 rillig char *(*fn)(int, int) = NULL;
885 1.36 rillig //indent end
886 1.36 rillig
887 1.36 rillig /* XXX: The parameter '(int)' is wrongly interpreted as a type cast. */
888 1.36 rillig /* XXX: The parameter '(int, int)' is wrongly interpreted as a type cast. */
889 1.36 rillig //indent run-equals-input -di0
890