Home | History | Annotate | Line # | Download | only in indent
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