fmt_decl.c revision 1.40 1 1.40 rillig /* $NetBSD: fmt_decl.c,v 1.40 2023/05/15 15:04: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.39 rillig void single_param(int) __attribute__((__noreturn__)) ;
168 1.39 rillig void function(const char *, ...) __attribute__((format(printf, 1, 2))) ;
169 1.35 rillig //indent end
170 1.25 rillig
171 1.35 rillig //indent run -di0
172 1.39 rillig void single_param(int) __attribute__((__noreturn__));
173 1.39 rillig void function(const char *, ...) __attribute__((format(printf, 1, 2)));
174 1.35 rillig //indent end
175 1.25 rillig
176 1.35 rillig //indent run
177 1.39 rillig void single_param(int) __attribute__((__noreturn__));
178 1.39 rillig void function(const char *, ...) __attribute__((format(printf, 1, 2)));
179 1.35 rillig //indent end
180 1.25 rillig
181 1.25 rillig
182 1.35 rillig //indent input
183 1.1 rillig static
184 1.1 rillig _attribute_printf(1, 2)
185 1.1 rillig void
186 1.1 rillig print_error(const char *fmt,...)
187 1.1 rillig {
188 1.1 rillig }
189 1.35 rillig //indent end
190 1.1 rillig
191 1.35 rillig //indent run
192 1.1 rillig static
193 1.1 rillig _attribute_printf(1, 2)
194 1.1 rillig void
195 1.1 rillig print_error(const char *fmt, ...)
196 1.1 rillig {
197 1.2 rillig }
198 1.35 rillig //indent end
199 1.2 rillig
200 1.2 rillig
201 1.35 rillig //indent input
202 1.2 rillig static _attribute_printf(1, 2)
203 1.2 rillig void
204 1.2 rillig print_error(const char *fmt,...)
205 1.2 rillig {
206 1.2 rillig }
207 1.35 rillig //indent end
208 1.1 rillig
209 1.35 rillig //indent run
210 1.2 rillig static _attribute_printf(1, 2)
211 1.2 rillig void
212 1.2 rillig print_error(const char *fmt, ...)
213 1.2 rillig {
214 1.2 rillig }
215 1.35 rillig //indent end
216 1.2 rillig
217 1.2 rillig
218 1.35 rillig //indent input
219 1.2 rillig static void _attribute_printf(1, 2)
220 1.2 rillig print_error(const char *fmt,...)
221 1.2 rillig {
222 1.2 rillig }
223 1.35 rillig //indent end
224 1.2 rillig
225 1.35 rillig //indent run
226 1.2 rillig static void
227 1.2 rillig _attribute_printf(1, 2)
228 1.2 rillig print_error(const char *fmt, ...)
229 1.2 rillig {
230 1.1 rillig }
231 1.35 rillig //indent end
232 1.1 rillig
233 1.1 rillig
234 1.3 rillig /* See FreeBSD r309380 */
235 1.35 rillig //indent input
236 1.1 rillig static LIST_HEAD(, alq) ald_active;
237 1.19 rillig static int ald_shutting_down = 0;
238 1.1 rillig struct thread *ald_thread;
239 1.35 rillig //indent end
240 1.1 rillig
241 1.35 rillig //indent run
242 1.1 rillig static LIST_HEAD(, alq) ald_active;
243 1.19 rillig static int ald_shutting_down = 0;
244 1.1 rillig struct thread *ald_thread;
245 1.35 rillig //indent end
246 1.1 rillig
247 1.1 rillig
248 1.35 rillig //indent input
249 1.1 rillig static int
250 1.2 rillig old_style_definition(a, b, c)
251 1.2 rillig struct thread *a;
252 1.2 rillig int b;
253 1.2 rillig double ***c;
254 1.1 rillig {
255 1.1 rillig
256 1.1 rillig }
257 1.35 rillig //indent end
258 1.1 rillig
259 1.35 rillig //indent run
260 1.1 rillig static int
261 1.2 rillig old_style_definition(a, b, c)
262 1.2 rillig struct thread *a;
263 1.2 rillig int b;
264 1.2 rillig double ***c;
265 1.1 rillig {
266 1.1 rillig
267 1.1 rillig }
268 1.35 rillig //indent end
269 1.1 rillig
270 1.1 rillig
271 1.1 rillig /*
272 1.1 rillig * Demonstrate how variable declarations are broken into several lines when
273 1.1 rillig * the line length limit is set quite low.
274 1.1 rillig */
275 1.35 rillig //indent input
276 1.7 rillig struct s a,b;
277 1.1 rillig struct s0 a,b;
278 1.1 rillig struct s01 a,b;
279 1.1 rillig struct s012 a,b;
280 1.1 rillig struct s0123 a,b;
281 1.1 rillig struct s01234 a,b;
282 1.1 rillig struct s012345 a,b;
283 1.1 rillig struct s0123456 a,b;
284 1.1 rillig struct s01234567 a,b;
285 1.1 rillig struct s012345678 a,b;
286 1.1 rillig struct s0123456789 a,b;
287 1.1 rillig struct s01234567890 a,b;
288 1.1 rillig struct s012345678901 a,b;
289 1.1 rillig struct s0123456789012 a,b;
290 1.1 rillig struct s01234567890123 a,b;
291 1.35 rillig //indent end
292 1.1 rillig
293 1.35 rillig //indent run -l20 -di0
294 1.7 rillig struct s a, b;
295 1.7 rillig /* $ XXX: See process_comma, varname_len for why this line is broken. */
296 1.1 rillig struct s0 a,
297 1.1 rillig b;
298 1.7 rillig /* $ XXX: The indentation of the second line is wrong. The variable names */
299 1.7 rillig /* $ XXX: 'a' and 'b' should be in the same column; the word 'struct' is */
300 1.7 rillig /* $ XXX: missing in the calculation for the indentation. */
301 1.1 rillig struct s01 a,
302 1.1 rillig b;
303 1.1 rillig struct s012 a,
304 1.1 rillig b;
305 1.1 rillig struct s0123 a,
306 1.1 rillig b;
307 1.1 rillig struct s01234 a,
308 1.1 rillig b;
309 1.1 rillig struct s012345 a,
310 1.1 rillig b;
311 1.1 rillig struct s0123456 a,
312 1.1 rillig b;
313 1.1 rillig struct s01234567 a,
314 1.1 rillig b;
315 1.1 rillig struct s012345678 a,
316 1.1 rillig b;
317 1.1 rillig struct s0123456789 a,
318 1.1 rillig b;
319 1.1 rillig struct s01234567890 a,
320 1.1 rillig b;
321 1.1 rillig struct s012345678901 a,
322 1.1 rillig b;
323 1.1 rillig struct s0123456789012 a,
324 1.1 rillig b;
325 1.1 rillig struct s01234567890123 a,
326 1.1 rillig b;
327 1.35 rillig //indent end
328 1.2 rillig
329 1.2 rillig
330 1.35 rillig //indent input
331 1.2 rillig char * x(void)
332 1.2 rillig {
333 1.2 rillig type identifier;
334 1.2 rillig type *pointer;
335 1.2 rillig unused * value;
336 1.2 rillig (void)unused * value;
337 1.2 rillig
338 1.2 rillig dmax = (double)3 * 10.0;
339 1.2 rillig dmin = (double)dmax * 10.0;
340 1.2 rillig davg = (double)dmax * dmin;
341 1.2 rillig
342 1.2 rillig return NULL;
343 1.2 rillig }
344 1.35 rillig //indent end
345 1.2 rillig
346 1.35 rillig //indent run
347 1.2 rillig char *
348 1.2 rillig x(void)
349 1.2 rillig {
350 1.2 rillig type identifier;
351 1.2 rillig type *pointer;
352 1.2 rillig unused *value;
353 1.2 rillig (void)unused * value;
354 1.2 rillig
355 1.2 rillig dmax = (double)3 * 10.0;
356 1.2 rillig dmin = (double)dmax * 10.0;
357 1.2 rillig davg = (double)dmax * dmin;
358 1.2 rillig
359 1.2 rillig return NULL;
360 1.2 rillig }
361 1.35 rillig //indent end
362 1.2 rillig
363 1.21 rillig
364 1.35 rillig //indent input
365 1.2 rillig int *
366 1.2 rillig y(void) {
367 1.2 rillig
368 1.2 rillig }
369 1.2 rillig
370 1.2 rillig int
371 1.2 rillig z(void) {
372 1.2 rillig
373 1.2 rillig }
374 1.35 rillig //indent end
375 1.2 rillig
376 1.35 rillig //indent run
377 1.2 rillig int *
378 1.2 rillig y(void)
379 1.2 rillig {
380 1.2 rillig
381 1.2 rillig }
382 1.2 rillig
383 1.2 rillig int
384 1.2 rillig z(void)
385 1.2 rillig {
386 1.2 rillig
387 1.2 rillig }
388 1.35 rillig //indent end
389 1.2 rillig
390 1.2 rillig
391 1.35 rillig //indent input
392 1.2 rillig int x;
393 1.2 rillig int *y;
394 1.2 rillig int * * * * z;
395 1.35 rillig //indent end
396 1.2 rillig
397 1.35 rillig //indent run
398 1.2 rillig int x;
399 1.2 rillig int *y;
400 1.2 rillig int ****z;
401 1.35 rillig //indent end
402 1.4 rillig
403 1.4 rillig
404 1.35 rillig //indent input
405 1.4 rillig int main(void) {
406 1.4 rillig char (*f1)() = NULL;
407 1.4 rillig char *(*f1)() = NULL;
408 1.4 rillig char *(*f2)();
409 1.4 rillig }
410 1.35 rillig //indent end
411 1.4 rillig
412 1.6 rillig /*
413 1.6 rillig * Before NetBSD io.c 1.103 from 2021-10-27, indent wrongly placed the second
414 1.6 rillig * and third variable declaration in column 1. This bug has been introduced
415 1.6 rillig * to NetBSD when FreeBSD indent was imported in 2019.
416 1.6 rillig */
417 1.35 rillig //indent run -ldi0
418 1.4 rillig int
419 1.4 rillig main(void)
420 1.4 rillig {
421 1.4 rillig char (*f1)() = NULL;
422 1.6 rillig char *(*f1)() = NULL;
423 1.6 rillig char *(*f2)();
424 1.4 rillig }
425 1.35 rillig //indent end
426 1.5 rillig
427 1.35 rillig //indent run
428 1.5 rillig int
429 1.5 rillig main(void)
430 1.5 rillig {
431 1.5 rillig /* $ XXX: Not really pretty, the name 'f1' should be aligned, if at all. */
432 1.5 rillig char (*f1)() = NULL;
433 1.5 rillig /* $ XXX: Not really pretty, the name 'f1' should be aligned, if at all. */
434 1.6 rillig char *(* f1)() = NULL;
435 1.5 rillig /* $ XXX: Not really pretty, the name 'f2' should be aligned, if at all. */
436 1.6 rillig char *(* f2)();
437 1.5 rillig }
438 1.35 rillig //indent end
439 1.10 rillig
440 1.10 rillig
441 1.10 rillig /*
442 1.10 rillig * In some ancient time long before ISO C90, variable declarations with
443 1.10 rillig * initializer could be written without '='. The C Programming Language from
444 1.10 rillig * 1978 doesn't mention this form anymore.
445 1.18 rillig *
446 1.18 rillig * Before NetBSD lexi.c 1.123 from 2021-10-31, indent treated the '-' as a
447 1.18 rillig * unary operator.
448 1.10 rillig */
449 1.35 rillig //indent input
450 1.10 rillig int a - 1;
451 1.10 rillig {
452 1.10 rillig int a - 1;
453 1.10 rillig }
454 1.35 rillig //indent end
455 1.10 rillig
456 1.35 rillig //indent run -di0
457 1.11 rillig int a - 1;
458 1.10 rillig {
459 1.11 rillig int a - 1;
460 1.10 rillig }
461 1.35 rillig //indent end
462 1.14 rillig
463 1.14 rillig
464 1.14 rillig /*
465 1.20 rillig * Between 2019-04-04 and before lexi.c 1.146 from 2021-11-19, the indentation
466 1.18 rillig * of the '*' depended on the function name, which did not make sense. For
467 1.18 rillig * function names that matched [A-Za-z]+, the '*' was placed correctly, for
468 1.18 rillig * all other function names (containing [$0-9_]) the '*' was right-aligned on
469 1.20 rillig * the declaration indentation, which defaults to 16.
470 1.14 rillig */
471 1.35 rillig //indent input
472 1.14 rillig int *
473 1.14 rillig f2(void)
474 1.14 rillig {
475 1.14 rillig }
476 1.14 rillig
477 1.14 rillig int *
478 1.14 rillig yy(void)
479 1.14 rillig {
480 1.14 rillig }
481 1.14 rillig
482 1.14 rillig int *
483 1.18 rillig int_create(void)
484 1.14 rillig {
485 1.14 rillig }
486 1.35 rillig //indent end
487 1.15 rillig
488 1.35 rillig //indent run-equals-input
489 1.18 rillig
490 1.15 rillig
491 1.15 rillig /*
492 1.15 rillig * Since 2019-04-04, the space between the '){' is missing.
493 1.15 rillig */
494 1.35 rillig //indent input
495 1.15 rillig int *
496 1.15 rillig function_name_____20________30________40________50
497 1.15 rillig (void)
498 1.15 rillig {}
499 1.35 rillig //indent end
500 1.15 rillig
501 1.38 rillig /*
502 1.38 rillig * Before 2023-05-11, indent moved the '{' right after the '(void)', without
503 1.38 rillig * any space in between.
504 1.38 rillig */
505 1.35 rillig //indent run
506 1.15 rillig int *function_name_____20________30________40________50
507 1.37 rillig (void)
508 1.37 rillig {
509 1.15 rillig }
510 1.35 rillig //indent end
511 1.15 rillig
512 1.15 rillig
513 1.15 rillig /*
514 1.17 rillig * Since 2019-04-04 and before lexi.c 1.144 from 2021-11-19, some function
515 1.17 rillig * names were preserved while others were silently discarded.
516 1.15 rillig */
517 1.35 rillig //indent input
518 1.15 rillig int *
519 1.15 rillig aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
520 1.15 rillig (void)
521 1.15 rillig {}
522 1.35 rillig //indent end
523 1.15 rillig
524 1.38 rillig /*
525 1.38 rillig * Before 2023-05-11, indent moved the '{' right after the '(void)', without
526 1.38 rillig * any space in between.
527 1.38 rillig */
528 1.35 rillig //indent run
529 1.16 rillig int *aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
530 1.37 rillig (void)
531 1.37 rillig {
532 1.15 rillig }
533 1.35 rillig //indent end
534 1.22 rillig
535 1.22 rillig
536 1.22 rillig /*
537 1.22 rillig * Before 1990, when C90 standardized function prototypes, a function
538 1.22 rillig * declaration or definition did not contain a '*' that may have looked
539 1.22 rillig * similar to the binary operator '*' because it was surrounded by two
540 1.22 rillig * identifiers.
541 1.22 rillig *
542 1.26 rillig * As of 2021-11-21, indent interpreted the '*' in the function declaration in
543 1.26 rillig * line 1 as a binary operator, even though the '*' was followed by a ','
544 1.26 rillig * directly. This was not visible in the output though since indent never
545 1.26 rillig * outputs a space before a comma.
546 1.22 rillig *
547 1.26 rillig * In the function declaration in line 2 and the function definition in line
548 1.26 rillig * 5, indent interpreted the '*' as a binary operator as well and accordingly
549 1.26 rillig * placed spaces around the '*'. On a very low syntactical analysis level,
550 1.26 rillig * this may have made sense since the '*' was surrounded by words, but still
551 1.26 rillig * the '*' is part of a declaration, where a binary operator does not make
552 1.26 rillig * sense.
553 1.26 rillig *
554 1.26 rillig * Essentially, as of 2021, indent had missed the last 31 years of advances in
555 1.26 rillig * the C programming language, in particular the invention of function
556 1.26 rillig * prototypes. Instead, the workaround had been to require all type names to
557 1.26 rillig * be specified via the options '-ta' and '-T'. This put the burden on the
558 1.26 rillig * user instead of the implementer.
559 1.26 rillig *
560 1.26 rillig * Fixed in lexi.c 1.156 from 2021-11-25.
561 1.22 rillig */
562 1.35 rillig //indent input
563 1.22 rillig void buffer_add(buffer *, char);
564 1.22 rillig void buffer_add(buffer *buf, char ch);
565 1.22 rillig
566 1.22 rillig void
567 1.22 rillig buffer_add(buffer *buf, char ch)
568 1.22 rillig {
569 1.22 rillig *buf->e++ = ch;
570 1.22 rillig }
571 1.35 rillig //indent end
572 1.22 rillig
573 1.26 rillig /* Before lexi.c 1.156 from 2021-11-25, indent generated 'buffer * buf'. */
574 1.35 rillig //indent run
575 1.29 rillig void buffer_add(buffer *, char);
576 1.29 rillig /* $ FIXME: space after '*' */
577 1.29 rillig void buffer_add(buffer * buf, char ch);
578 1.29 rillig
579 1.29 rillig void
580 1.29 rillig buffer_add(buffer *buf, char ch)
581 1.29 rillig {
582 1.29 rillig *buf->e++ = ch;
583 1.29 rillig }
584 1.35 rillig //indent end
585 1.23 rillig
586 1.23 rillig
587 1.23 rillig /*
588 1.38 rillig * Before lexi.c 1.153 from 2021-11-25, indent did not recognize 'Token' as a
589 1.38 rillig * type name and then messed up the positioning of the '{'.
590 1.23 rillig */
591 1.35 rillig //indent input
592 1.23 rillig static Token
593 1.23 rillig ToToken(bool cond)
594 1.23 rillig {
595 1.23 rillig }
596 1.35 rillig //indent end
597 1.23 rillig
598 1.35 rillig //indent run-equals-input -TToken
599 1.34 rillig
600 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
601 1.35 rillig //indent run-equals-input
602 1.23 rillig
603 1.23 rillig
604 1.23 rillig /*
605 1.23 rillig * Indent gets easily confused by unknown type names in struct declarations.
606 1.23 rillig */
607 1.35 rillig //indent input
608 1.23 rillig typedef struct OpenDirs {
609 1.23 rillig CachedDirList list;
610 1.23 rillig HashTable /* of CachedDirListNode */ table;
611 1.23 rillig } OpenDirs;
612 1.35 rillig //indent end
613 1.23 rillig
614 1.23 rillig /* FIXME: The word 'HashTable' must not be aligned like a member name. */
615 1.35 rillig //indent run
616 1.23 rillig typedef struct OpenDirs {
617 1.23 rillig CachedDirList list;
618 1.23 rillig HashTable /* of CachedDirListNode */ table;
619 1.23 rillig } OpenDirs;
620 1.35 rillig //indent end
621 1.23 rillig
622 1.35 rillig //indent run-equals-input -THashTable
623 1.23 rillig
624 1.23 rillig
625 1.23 rillig /*
626 1.23 rillig * Indent gets easily confused by unknown type names, even in declarations
627 1.23 rillig * that are syntactically unambiguous.
628 1.23 rillig */
629 1.35 rillig //indent input
630 1.23 rillig static CachedDir *dot = NULL;
631 1.35 rillig //indent end
632 1.23 rillig
633 1.35 rillig //indent run-equals-input -TCachedDir
634 1.34 rillig
635 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
636 1.35 rillig //indent run-equals-input
637 1.23 rillig
638 1.23 rillig
639 1.23 rillig /*
640 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent easily got confused by unknown
641 1.26 rillig * type names in declarations and generated 'HashEntry * he' with an extra
642 1.26 rillig * space.
643 1.23 rillig */
644 1.35 rillig //indent input
645 1.23 rillig static CachedDir *
646 1.23 rillig CachedDir_New(const char *name)
647 1.23 rillig {
648 1.23 rillig }
649 1.35 rillig //indent end
650 1.23 rillig
651 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
652 1.35 rillig //indent run-equals-input
653 1.23 rillig
654 1.23 rillig
655 1.23 rillig /*
656 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent easily got confused by unknown
657 1.26 rillig * type names in declarations and generated 'CachedDir * dir' with an extra
658 1.26 rillig * space.
659 1.23 rillig */
660 1.35 rillig //indent input
661 1.23 rillig static CachedDir *
662 1.23 rillig CachedDir_Ref(CachedDir *dir)
663 1.23 rillig {
664 1.23 rillig }
665 1.35 rillig //indent end
666 1.23 rillig
667 1.35 rillig //indent run-equals-input
668 1.23 rillig
669 1.23 rillig
670 1.23 rillig /*
671 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent easily got confused by unknown
672 1.26 rillig * type names in declarations and generated 'HashEntry * he' with an extra
673 1.26 rillig * space.
674 1.26 rillig *
675 1.26 rillig * Before lexi.c 1.153 from 2021-11-25, indent also placed the '{' at the end
676 1.26 rillig * of the line.
677 1.23 rillig */
678 1.35 rillig //indent input
679 1.23 rillig static bool
680 1.23 rillig HashEntry_KeyEquals(const HashEntry *he, Substring key)
681 1.23 rillig {
682 1.23 rillig }
683 1.35 rillig //indent end
684 1.23 rillig
685 1.35 rillig //indent run-equals-input
686 1.23 rillig
687 1.23 rillig
688 1.23 rillig /*
689 1.26 rillig * Before lexi.c 1.156 from 2021-11-25, indent didn't notice that the two '*'
690 1.26 rillig * are in a declaration, instead it interpreted the first '*' as a binary
691 1.26 rillig * operator, therefore generating 'CachedDir * *var' with an extra space.
692 1.23 rillig */
693 1.35 rillig //indent input
694 1.23 rillig static void
695 1.23 rillig CachedDir_Assign(CachedDir **var, CachedDir *dir)
696 1.23 rillig {
697 1.23 rillig }
698 1.35 rillig //indent end
699 1.23 rillig
700 1.35 rillig //indent run-equals-input
701 1.34 rillig
702 1.35 rillig //indent run-equals-input -TCachedDir
703 1.23 rillig
704 1.23 rillig
705 1.23 rillig /*
706 1.24 rillig * Before lexi.c 1.153 from 2021-11-25, all initializer expressions after the
707 1.24 rillig * first one were indented as if they would be statement continuations. This
708 1.24 rillig * was because the token 'Shell' was identified as a word, not as a type name.
709 1.23 rillig */
710 1.35 rillig //indent input
711 1.24 rillig static Shell shells[] = {
712 1.23 rillig {
713 1.23 rillig first,
714 1.23 rillig second,
715 1.23 rillig },
716 1.23 rillig };
717 1.35 rillig //indent end
718 1.23 rillig
719 1.24 rillig /* Since lexi.c 1.153 from 2021-11-25. */
720 1.35 rillig //indent run-equals-input
721 1.23 rillig
722 1.23 rillig
723 1.23 rillig /*
724 1.27 rillig * Before lexi.c 1.158 from 2021-11-25, indent easily got confused by function
725 1.27 rillig * attribute macros that followed the function declaration. Its primitive
726 1.27 rillig * heuristic between deciding between a function declaration and a function
727 1.27 rillig * definition only looked for ')' immediately followed by ',' or ';'. This was
728 1.27 rillig * sufficient for well-formatted code before 1990. With the addition of
729 1.27 rillig * function prototypes and GCC attributes, the situation became more
730 1.27 rillig * complicated, and it took indent 31 years to adapt to this new reality.
731 1.23 rillig */
732 1.35 rillig //indent input
733 1.23 rillig static void JobInterrupt(bool, int) MAKE_ATTR_DEAD;
734 1.23 rillig static void JobRestartJobs(void);
735 1.35 rillig //indent end
736 1.23 rillig
737 1.35 rillig //indent run
738 1.39 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 1.40 rillig
891 1.40 rillig
892 1.40 rillig /*
893 1.40 rillig * Depending on the line break in the function header, the spaces around the
894 1.40 rillig * '||' operator were removed.
895 1.40 rillig */
896 1.40 rillig //indent input
897 1.40 rillig bool is_identifier_start(char ch)
898 1.40 rillig {
899 1.40 rillig return ch_isalpha(ch) || ch == '_';
900 1.40 rillig }
901 1.40 rillig
902 1.40 rillig bool
903 1.40 rillig is_identifier_start(char ch)
904 1.40 rillig {
905 1.40 rillig return ch_isalpha(ch) || ch == '_';
906 1.40 rillig }
907 1.40 rillig //indent end
908 1.40 rillig
909 1.40 rillig //indent run
910 1.40 rillig bool
911 1.40 rillig is_identifier_start(char ch)
912 1.40 rillig {
913 1.40 rillig return ch_isalpha(ch) || ch == '_';
914 1.40 rillig }
915 1.40 rillig
916 1.40 rillig bool
917 1.40 rillig is_identifier_start(char ch)
918 1.40 rillig {
919 1.40 rillig return ch_isalpha(ch)||ch == '_';
920 1.40 rillig }
921 1.40 rillig //indent end
922