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