fmt_decl.c revision 1.22 1 1.22 rillig /* $NetBSD: fmt_decl.c,v 1.22 2021/11/21 11:02:25 rillig Exp $ */
2 1.1 rillig /* $FreeBSD: head/usr.bin/indent/tests/declarations.0 334478 2018-06-01 09:41:15Z pstef $ */
3 1.1 rillig
4 1.19 rillig /*
5 1.19 rillig * Tests for declarations of global variables, external functions, and local
6 1.19 rillig * variables.
7 1.19 rillig *
8 1.19 rillig * See also:
9 1.19 rillig * opt_di.c
10 1.19 rillig */
11 1.19 rillig
12 1.1 rillig /* See FreeBSD r303570 */
13 1.1 rillig
14 1.19 rillig /*
15 1.19 rillig * A type definition usually declares a single type, so there is no need to
16 1.19 rillig * align the newly declared type name with the other variables.
17 1.19 rillig */
18 1.1 rillig #indent input
19 1.19 rillig typedef void ( * voidptr ) ( int * ) ;
20 1.1 rillig #indent end
21 1.1 rillig
22 1.1 rillig #indent run
23 1.1 rillig typedef void (*voidptr)(int *);
24 1.1 rillig #indent end
25 1.1 rillig
26 1.1 rillig
27 1.19 rillig /*
28 1.19 rillig * In variable declarations, the names of the first declarators are indented
29 1.19 rillig * by the amount given in '-di', which defaults to 16.
30 1.19 rillig */
31 1.19 rillig #indent input
32 1.19 rillig extern void ( * function_pointer ) ( int * ) ;
33 1.19 rillig extern void * pointer;
34 1.19 rillig #indent end
35 1.19 rillig
36 1.19 rillig #indent run
37 1.19 rillig /* $ XXX: Why is the token 'function_pointer' not aligned with 'pointer'? */
38 1.19 rillig extern void (*function_pointer)(int *);
39 1.19 rillig extern void *pointer;
40 1.19 rillig #indent end
41 1.19 rillig
42 1.19 rillig
43 1.1 rillig #indent input
44 1.1 rillig static const struct
45 1.1 rillig {
46 1.1 rillig double x;
47 1.1 rillig double y, z;
48 1.1 rillig } n[m + 1] =
49 1.1 rillig {
50 1.1 rillig {
51 1.1 rillig .0,
52 1.1 rillig .9,
53 1.1 rillig 5
54 1.1 rillig }
55 1.1 rillig };
56 1.1 rillig #indent end
57 1.1 rillig
58 1.1 rillig #indent run
59 1.1 rillig static const struct {
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.1 rillig #indent end
71 1.1 rillig
72 1.1 rillig
73 1.1 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.1 rillig #indent end
80 1.1 rillig
81 1.1 rillig #indent run
82 1.1 rillig typedef struct Complex {
83 1.1 rillig double x;
84 1.1 rillig double y;
85 1.1 rillig } Complex;
86 1.1 rillig #indent end
87 1.1 rillig
88 1.1 rillig
89 1.8 rillig /*
90 1.13 rillig * As of 2021-11-07, indent parses the following function definition as these
91 1.8 rillig * tokens:
92 1.8 rillig *
93 1.13 rillig * line 1: type_outside_parentheses "void"
94 1.8 rillig * line 1: newline "\n"
95 1.8 rillig * line 2: funcname "t1"
96 1.8 rillig * line 2: newline "\n" repeated, see search_stmt
97 1.8 rillig * line 3: funcname "t1" XXX: wrong line_no
98 1.8 rillig * line 3: lparen_or_lbracket "("
99 1.13 rillig * line 3: type_in_parentheses "char"
100 1.8 rillig * line 3: unary_op "*"
101 1.13 rillig * line 3: word "a"
102 1.8 rillig * line 3: comma ","
103 1.13 rillig * line 3: type_in_parentheses "int"
104 1.13 rillig * line 3: word "b"
105 1.8 rillig * line 3: comma ","
106 1.8 rillig * line 3: newline "\n"
107 1.13 rillig * line 4: type_in_parentheses "void"
108 1.8 rillig * line 4: lparen_or_lbracket "("
109 1.8 rillig * line 4: unary_op "*"
110 1.13 rillig * line 4: word "fn"
111 1.8 rillig * line 4: rparen_or_rbracket ")"
112 1.8 rillig * line 4: lparen_or_lbracket "("
113 1.13 rillig * line 4: type_in_parentheses "void"
114 1.8 rillig * line 4: rparen_or_rbracket ")"
115 1.8 rillig * line 4: rparen_or_rbracket ")"
116 1.8 rillig * line 4: newline "\n"
117 1.8 rillig * line 5: lbrace "{"
118 1.8 rillig * line 5: lbrace "{" repeated, see search_stmt
119 1.8 rillig * line 5: newline "\n" FIXME: there is no newline in the source
120 1.8 rillig * line 6: rbrace "}"
121 1.8 rillig * line 6: eof "\n"
122 1.8 rillig */
123 1.1 rillig #indent input
124 1.1 rillig void
125 1.1 rillig t1 (char *a, int b,
126 1.1 rillig void (*fn)(void))
127 1.1 rillig {}
128 1.1 rillig #indent end
129 1.1 rillig
130 1.1 rillig #indent run
131 1.1 rillig void
132 1.1 rillig t1(char *a, int b,
133 1.1 rillig void (*fn)(void))
134 1.1 rillig {
135 1.1 rillig }
136 1.1 rillig #indent end
137 1.1 rillig
138 1.1 rillig
139 1.19 rillig /* See opt_bc.c. */
140 1.1 rillig #indent input
141 1.1 rillig void t2 (char *x, int y)
142 1.1 rillig {
143 1.1 rillig int a,
144 1.1 rillig b,
145 1.1 rillig c;
146 1.1 rillig int
147 1.1 rillig *d,
148 1.1 rillig *e,
149 1.1 rillig *f;
150 1.1 rillig int (*g)(),
151 1.1 rillig (*h)(),
152 1.1 rillig (*i)();
153 1.1 rillig int j,
154 1.1 rillig k,
155 1.1 rillig l;
156 1.1 rillig int m
157 1.1 rillig ,n
158 1.1 rillig ,o
159 1.1 rillig ;
160 1.1 rillig int chars[ /* push the comma beyond column 74 .... */ ], x;
161 1.1 rillig }
162 1.1 rillig #indent end
163 1.1 rillig
164 1.1 rillig #indent run
165 1.1 rillig void
166 1.1 rillig t2(char *x, int y)
167 1.1 rillig {
168 1.1 rillig int a, b, c;
169 1.1 rillig int
170 1.1 rillig *d, *e, *f;
171 1.1 rillig int (*g)(), (*h)(), (*i)();
172 1.1 rillig int j, k, l;
173 1.1 rillig int m
174 1.1 rillig ,n
175 1.1 rillig ,o
176 1.1 rillig ;
177 1.1 rillig int chars[ /* push the comma beyond column 74 .... */ ],
178 1.1 rillig x;
179 1.1 rillig }
180 1.1 rillig #indent end
181 1.1 rillig
182 1.1 rillig
183 1.1 rillig #indent input
184 1.1 rillig const int int_minimum_size =
185 1.1 rillig MAXALIGN(offsetof(int, test)) + MAXIMUM_ALIGNOF;
186 1.1 rillig #indent end
187 1.1 rillig
188 1.1 rillig #indent run-equals-input
189 1.1 rillig
190 1.1 rillig
191 1.1 rillig #indent input
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.1 rillig }
198 1.1 rillig #indent end
199 1.1 rillig
200 1.1 rillig #indent run
201 1.1 rillig static
202 1.1 rillig _attribute_printf(1, 2)
203 1.1 rillig void
204 1.1 rillig print_error(const char *fmt, ...)
205 1.1 rillig {
206 1.2 rillig }
207 1.2 rillig #indent end
208 1.2 rillig
209 1.2 rillig
210 1.2 rillig #indent input
211 1.2 rillig static _attribute_printf(1, 2)
212 1.2 rillig void
213 1.2 rillig print_error(const char *fmt,...)
214 1.2 rillig {
215 1.2 rillig }
216 1.2 rillig #indent end
217 1.1 rillig
218 1.2 rillig #indent run
219 1.2 rillig static _attribute_printf(1, 2)
220 1.2 rillig void
221 1.2 rillig print_error(const char *fmt, ...)
222 1.2 rillig {
223 1.2 rillig }
224 1.2 rillig #indent end
225 1.2 rillig
226 1.2 rillig
227 1.2 rillig #indent input
228 1.2 rillig static void _attribute_printf(1, 2)
229 1.2 rillig print_error(const char *fmt,...)
230 1.2 rillig {
231 1.2 rillig }
232 1.2 rillig #indent end
233 1.2 rillig
234 1.2 rillig #indent run
235 1.2 rillig static void
236 1.2 rillig _attribute_printf(1, 2)
237 1.2 rillig print_error(const char *fmt, ...)
238 1.2 rillig {
239 1.1 rillig }
240 1.1 rillig #indent end
241 1.1 rillig
242 1.1 rillig
243 1.3 rillig /* See FreeBSD r309380 */
244 1.1 rillig #indent input
245 1.1 rillig static LIST_HEAD(, alq) ald_active;
246 1.19 rillig static int ald_shutting_down = 0;
247 1.1 rillig struct thread *ald_thread;
248 1.1 rillig #indent end
249 1.1 rillig
250 1.1 rillig #indent run
251 1.1 rillig static LIST_HEAD(, alq) ald_active;
252 1.19 rillig static int ald_shutting_down = 0;
253 1.1 rillig struct thread *ald_thread;
254 1.1 rillig #indent end
255 1.1 rillig
256 1.1 rillig
257 1.1 rillig #indent input
258 1.1 rillig static int
259 1.2 rillig old_style_definition(a, b, c)
260 1.2 rillig struct thread *a;
261 1.2 rillig int b;
262 1.2 rillig double ***c;
263 1.1 rillig {
264 1.1 rillig
265 1.1 rillig }
266 1.1 rillig #indent end
267 1.1 rillig
268 1.1 rillig #indent run
269 1.1 rillig static int
270 1.2 rillig old_style_definition(a, b, c)
271 1.2 rillig struct thread *a;
272 1.2 rillig int b;
273 1.2 rillig double ***c;
274 1.1 rillig {
275 1.1 rillig
276 1.1 rillig }
277 1.1 rillig #indent end
278 1.1 rillig
279 1.1 rillig
280 1.1 rillig /*
281 1.1 rillig * Demonstrate how variable declarations are broken into several lines when
282 1.1 rillig * the line length limit is set quite low.
283 1.1 rillig */
284 1.1 rillig #indent input
285 1.7 rillig struct s a,b;
286 1.1 rillig struct s0 a,b;
287 1.1 rillig struct s01 a,b;
288 1.1 rillig struct s012 a,b;
289 1.1 rillig struct s0123 a,b;
290 1.1 rillig struct s01234 a,b;
291 1.1 rillig struct s012345 a,b;
292 1.1 rillig struct s0123456 a,b;
293 1.1 rillig struct s01234567 a,b;
294 1.1 rillig struct s012345678 a,b;
295 1.1 rillig struct s0123456789 a,b;
296 1.1 rillig struct s01234567890 a,b;
297 1.1 rillig struct s012345678901 a,b;
298 1.1 rillig struct s0123456789012 a,b;
299 1.1 rillig struct s01234567890123 a,b;
300 1.1 rillig #indent end
301 1.1 rillig
302 1.1 rillig #indent run -l20 -di0
303 1.7 rillig struct s a, b;
304 1.7 rillig /* $ XXX: See process_comma, varname_len for why this line is broken. */
305 1.1 rillig struct s0 a,
306 1.1 rillig b;
307 1.7 rillig /* $ XXX: The indentation of the second line is wrong. The variable names */
308 1.7 rillig /* $ XXX: 'a' and 'b' should be in the same column; the word 'struct' is */
309 1.7 rillig /* $ XXX: missing in the calculation for the indentation. */
310 1.1 rillig struct s01 a,
311 1.1 rillig b;
312 1.1 rillig struct s012 a,
313 1.1 rillig b;
314 1.1 rillig struct s0123 a,
315 1.1 rillig b;
316 1.1 rillig struct s01234 a,
317 1.1 rillig b;
318 1.1 rillig struct s012345 a,
319 1.1 rillig b;
320 1.1 rillig struct s0123456 a,
321 1.1 rillig b;
322 1.1 rillig struct s01234567 a,
323 1.1 rillig b;
324 1.1 rillig struct s012345678 a,
325 1.1 rillig b;
326 1.1 rillig struct s0123456789 a,
327 1.1 rillig b;
328 1.1 rillig struct s01234567890 a,
329 1.1 rillig b;
330 1.1 rillig struct s012345678901 a,
331 1.1 rillig b;
332 1.1 rillig struct s0123456789012 a,
333 1.1 rillig b;
334 1.1 rillig struct s01234567890123 a,
335 1.1 rillig b;
336 1.1 rillig #indent end
337 1.2 rillig
338 1.2 rillig
339 1.2 rillig #indent input
340 1.2 rillig char * x(void)
341 1.2 rillig {
342 1.2 rillig type identifier;
343 1.2 rillig type *pointer;
344 1.2 rillig unused * value;
345 1.2 rillig (void)unused * value;
346 1.2 rillig
347 1.2 rillig dmax = (double)3 * 10.0;
348 1.2 rillig dmin = (double)dmax * 10.0;
349 1.2 rillig davg = (double)dmax * dmin;
350 1.2 rillig
351 1.2 rillig return NULL;
352 1.2 rillig }
353 1.2 rillig #indent end
354 1.2 rillig
355 1.2 rillig #indent run
356 1.2 rillig char *
357 1.2 rillig x(void)
358 1.2 rillig {
359 1.2 rillig type identifier;
360 1.2 rillig type *pointer;
361 1.2 rillig unused *value;
362 1.2 rillig (void)unused * value;
363 1.2 rillig
364 1.2 rillig dmax = (double)3 * 10.0;
365 1.2 rillig dmin = (double)dmax * 10.0;
366 1.2 rillig davg = (double)dmax * dmin;
367 1.2 rillig
368 1.2 rillig return NULL;
369 1.2 rillig }
370 1.2 rillig #indent end
371 1.2 rillig
372 1.21 rillig
373 1.2 rillig #indent input
374 1.2 rillig int *
375 1.2 rillig y(void) {
376 1.2 rillig
377 1.2 rillig }
378 1.2 rillig
379 1.2 rillig int
380 1.2 rillig z(void) {
381 1.2 rillig
382 1.2 rillig }
383 1.2 rillig #indent end
384 1.2 rillig
385 1.2 rillig #indent run
386 1.2 rillig int *
387 1.2 rillig y(void)
388 1.2 rillig {
389 1.2 rillig
390 1.2 rillig }
391 1.2 rillig
392 1.2 rillig int
393 1.2 rillig z(void)
394 1.2 rillig {
395 1.2 rillig
396 1.2 rillig }
397 1.2 rillig #indent end
398 1.2 rillig
399 1.2 rillig
400 1.2 rillig #indent input
401 1.2 rillig int x;
402 1.2 rillig int *y;
403 1.2 rillig int * * * * z;
404 1.2 rillig #indent end
405 1.2 rillig
406 1.2 rillig #indent run
407 1.2 rillig int x;
408 1.2 rillig int *y;
409 1.2 rillig int ****z;
410 1.2 rillig #indent end
411 1.4 rillig
412 1.4 rillig
413 1.4 rillig #indent input
414 1.4 rillig int main(void) {
415 1.4 rillig char (*f1)() = NULL;
416 1.4 rillig char *(*f1)() = NULL;
417 1.4 rillig char *(*f2)();
418 1.4 rillig }
419 1.4 rillig #indent end
420 1.4 rillig
421 1.6 rillig /*
422 1.6 rillig * Before NetBSD io.c 1.103 from 2021-10-27, indent wrongly placed the second
423 1.6 rillig * and third variable declaration in column 1. This bug has been introduced
424 1.6 rillig * to NetBSD when FreeBSD indent was imported in 2019.
425 1.6 rillig */
426 1.4 rillig #indent run -ldi0
427 1.4 rillig int
428 1.4 rillig main(void)
429 1.4 rillig {
430 1.4 rillig char (*f1)() = NULL;
431 1.6 rillig char *(*f1)() = NULL;
432 1.6 rillig char *(*f2)();
433 1.4 rillig }
434 1.4 rillig #indent end
435 1.5 rillig
436 1.5 rillig #indent run
437 1.5 rillig int
438 1.5 rillig main(void)
439 1.5 rillig {
440 1.5 rillig /* $ XXX: Not really pretty, the name 'f1' should be aligned, if at all. */
441 1.5 rillig char (*f1)() = NULL;
442 1.5 rillig /* $ XXX: Not really pretty, the name 'f1' should be aligned, if at all. */
443 1.6 rillig char *(* f1)() = NULL;
444 1.5 rillig /* $ XXX: Not really pretty, the name 'f2' should be aligned, if at all. */
445 1.6 rillig char *(* f2)();
446 1.5 rillig }
447 1.5 rillig #indent end
448 1.10 rillig
449 1.10 rillig
450 1.10 rillig /*
451 1.10 rillig * In some ancient time long before ISO C90, variable declarations with
452 1.10 rillig * initializer could be written without '='. The C Programming Language from
453 1.10 rillig * 1978 doesn't mention this form anymore.
454 1.18 rillig *
455 1.18 rillig * Before NetBSD lexi.c 1.123 from 2021-10-31, indent treated the '-' as a
456 1.18 rillig * unary operator.
457 1.10 rillig */
458 1.10 rillig #indent input
459 1.10 rillig int a - 1;
460 1.10 rillig {
461 1.10 rillig int a - 1;
462 1.10 rillig }
463 1.10 rillig #indent end
464 1.10 rillig
465 1.10 rillig #indent run -di0
466 1.11 rillig int a - 1;
467 1.10 rillig {
468 1.11 rillig int a - 1;
469 1.10 rillig }
470 1.10 rillig #indent end
471 1.14 rillig
472 1.14 rillig
473 1.14 rillig /*
474 1.20 rillig * Between 2019-04-04 and before lexi.c 1.146 from 2021-11-19, the indentation
475 1.18 rillig * of the '*' depended on the function name, which did not make sense. For
476 1.18 rillig * function names that matched [A-Za-z]+, the '*' was placed correctly, for
477 1.18 rillig * all other function names (containing [$0-9_]) the '*' was right-aligned on
478 1.20 rillig * the declaration indentation, which defaults to 16.
479 1.14 rillig */
480 1.14 rillig #indent input
481 1.14 rillig int *
482 1.14 rillig f2(void)
483 1.14 rillig {
484 1.14 rillig }
485 1.14 rillig
486 1.14 rillig int *
487 1.14 rillig yy(void)
488 1.14 rillig {
489 1.14 rillig }
490 1.14 rillig
491 1.14 rillig int *
492 1.18 rillig int_create(void)
493 1.14 rillig {
494 1.14 rillig }
495 1.14 rillig #indent end
496 1.15 rillig
497 1.18 rillig #indent run-equals-input
498 1.18 rillig
499 1.15 rillig
500 1.15 rillig /*
501 1.15 rillig * Since 2019-04-04, the space between the '){' is missing.
502 1.15 rillig */
503 1.15 rillig #indent input
504 1.15 rillig int *
505 1.15 rillig function_name_____20________30________40________50
506 1.15 rillig (void)
507 1.15 rillig {}
508 1.15 rillig #indent end
509 1.15 rillig
510 1.15 rillig /* FIXME: The space between '){' is missing. */
511 1.15 rillig #indent run
512 1.15 rillig int *function_name_____20________30________40________50
513 1.15 rillig (void){
514 1.15 rillig }
515 1.15 rillig #indent end
516 1.15 rillig
517 1.15 rillig
518 1.15 rillig /*
519 1.17 rillig * Since 2019-04-04 and before lexi.c 1.144 from 2021-11-19, some function
520 1.17 rillig * names were preserved while others were silently discarded.
521 1.15 rillig */
522 1.15 rillig #indent input
523 1.15 rillig int *
524 1.15 rillig aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
525 1.15 rillig (void)
526 1.15 rillig {}
527 1.15 rillig #indent end
528 1.15 rillig
529 1.15 rillig #indent run
530 1.16 rillig int *aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
531 1.16 rillig (void){
532 1.15 rillig }
533 1.15 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.22 rillig * As of 2021-11-21, indent interprets the '*' in the function declaration in
543 1.22 rillig * line 1 as a binary operator, even though it is followed by a ',' directly.
544 1.22 rillig * In the function declaration in line 2, as well as the function definition
545 1.22 rillig * in line 4, indent interprets the '*' as a binary operator as well, which
546 1.22 rillig * kind of makes sense since it is surrounded by words, but it's still in a
547 1.22 rillig * declaration.
548 1.22 rillig *
549 1.22 rillig * Essentially, as of 2021, indent has missed the last 31 years of advances in
550 1.22 rillig * the C programming language. Instead, the workaround has been to pass all
551 1.22 rillig * type names via the options '-ta' and '-T'.
552 1.22 rillig */
553 1.22 rillig #indent input
554 1.22 rillig void buffer_add(buffer *, char);
555 1.22 rillig void buffer_add(buffer *buf, char ch);
556 1.22 rillig
557 1.22 rillig void
558 1.22 rillig buffer_add(buffer *buf, char ch)
559 1.22 rillig {
560 1.22 rillig *buf->e++ = ch;
561 1.22 rillig }
562 1.22 rillig #indent end
563 1.22 rillig
564 1.22 rillig #indent run
565 1.22 rillig void buffer_add(buffer *, char);
566 1.22 rillig void buffer_add(buffer * buf, char ch);
567 1.22 rillig
568 1.22 rillig void
569 1.22 rillig buffer_add(buffer * buf, char ch)
570 1.22 rillig {
571 1.22 rillig *buf->e++ = ch;
572 1.22 rillig }
573 1.22 rillig #indent end
574