Module Name:    src
Committed By:   rillig
Date:           Fri Jun 30 16:39:17 UTC 2023

Modified Files:
        src/tests/usr.bin/xlint/lint1: d_alignof.c expr_sizeof.c

Log Message:
tests/lint: extend tests for sizeof and alignof


To generate a diff of this commit:
cvs rdiff -u -r1.10 -r1.11 src/tests/usr.bin/xlint/lint1/d_alignof.c \
    src/tests/usr.bin/xlint/lint1/expr_sizeof.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tests/usr.bin/xlint/lint1/d_alignof.c
diff -u src/tests/usr.bin/xlint/lint1/d_alignof.c:1.10 src/tests/usr.bin/xlint/lint1/d_alignof.c:1.11
--- src/tests/usr.bin/xlint/lint1/d_alignof.c:1.10	Fri Jun 30 09:26:03 2023
+++ src/tests/usr.bin/xlint/lint1/d_alignof.c	Fri Jun 30 16:39:17 2023
@@ -1,4 +1,4 @@
-/*	$NetBSD: d_alignof.c,v 1.10 2023/06/30 09:26:03 rillig Exp $	*/
+/*	$NetBSD: d_alignof.c,v 1.11 2023/06/30 16:39:17 rillig Exp $	*/
 # 3 "d_alignof.c"
 
 /* https://gcc.gnu.org/onlinedocs/gcc/Alignment.html */
@@ -108,6 +108,9 @@ alignof_variants(void)
 	/* expect+1: error: cannot take size/alignment of incomplete type [143] */
 	typedef int incomplete_enum[-(int)__alignof(enum incomplete_enum)];
 
+	/* expect+1: error: cannot take size/alignment of incomplete type [143] */
+	typedef int incomplete_array[-(int)__alignof(int[])];
+
 	struct bit_fields {
 		_Bool bit_field:1;
 	};
@@ -117,7 +120,11 @@ alignof_variants(void)
 	 */
 	/* expect+2: error: cannot initialize typedef '00000000_tmp' [25] */
 	/* expect+1: error: cannot take size/alignment of bit-field [145] */
-	typedef int bit_field[-(int)__alignof((struct bit_fields){0}.bit_field)];
+	typedef int bit_field_1[-(int)__alignof((struct bit_fields){0}.bit_field)];
+
+	struct bit_fields bit_fields;
+	/* expect+1: error: cannot take size/alignment of bit-field [145] */
+	typedef int bit_field_2[-(int)__alignof(bit_fields.bit_field)];
 
 	/* expect+1: error: cannot take size/alignment of void [146] */
 	typedef int plain_void[-(int)__alignof(void)];
Index: src/tests/usr.bin/xlint/lint1/expr_sizeof.c
diff -u src/tests/usr.bin/xlint/lint1/expr_sizeof.c:1.10 src/tests/usr.bin/xlint/lint1/expr_sizeof.c:1.11
--- src/tests/usr.bin/xlint/lint1/expr_sizeof.c:1.10	Fri Jun 30 15:19:09 2023
+++ src/tests/usr.bin/xlint/lint1/expr_sizeof.c	Fri Jun 30 16:39:17 2023
@@ -1,4 +1,4 @@
-/*	$NetBSD: expr_sizeof.c,v 1.10 2023/06/30 15:19:09 rillig Exp $	*/
+/*	$NetBSD: expr_sizeof.c,v 1.11 2023/06/30 16:39:17 rillig Exp $	*/
 # 3 "expr_sizeof.c"
 
 /*
@@ -11,6 +11,7 @@
 /*
  * A sizeof expression can either take a type name or an expression.
  */
+
 void sink(unsigned long);
 
 struct {
@@ -164,3 +165,39 @@ anonymous_struct_and_union(void)
 	/* expect+1: error: negative array dimension (-48) [20] */
 	typedef int sizeof_us_16_32[-(int)sizeof(us_16_32)];
 }
+
+
+void
+sizeof_errors(void)
+{
+	/* expect+1: error: cannot take size/alignment of void [146] */
+	typedef int sizeof_void[-(int)sizeof(void)];
+
+	/*
+	 * A 'void array' gets replaced with an 'int array' before
+	 * type_size_in_bits gets to see it, thus the 256 * 4 = 1024.
+	 */
+	/* expect+2: error: illegal use of 'void' [18] */
+	/* expect+1: error: negative array dimension (-1024) [20] */
+	typedef int sizeof_void_array[-(int)sizeof(void[256])];
+
+	/* expect+1: warning: enum 'incomplete_enum' never defined [235] */
+	enum incomplete_enum;
+	/* expect+2: warning: cannot take size/alignment of incomplete type [143] */
+	/* expect+1: error: negative array dimension (-4) [20] */
+	typedef int sizeof_incomplete_enum[-(int)sizeof(enum incomplete_enum)];
+}
+
+
+/*
+ * Due to the 'double' member, the alignment of this struct is 8, so the size
+ * has to be 24 (or at least divisible by 8), otherwise the 'double' member
+ * would not get the correct alignment in an array of this struct.
+ */
+struct s24 {
+	char c0;
+	double d8;
+	char c16;
+};
+/* expect+1: error: negative array dimension (-24) [20] */
+typedef int sizeof_s24[-(int)sizeof(struct s24)];

Reply via email to