Home | History | Annotate | Line # | Download | only in indent
fmt_decl.c revision 1.21
      1  1.21  rillig /*	$NetBSD: fmt_decl.c,v 1.21 2021/11/20 11:13:18 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