mirror of
https://github.com/cc65/cc65.git
synced 2025-01-12 17:30:50 +00:00
Test to demonstrate issue #2566.
This commit is contained in:
parent
c52d7b27e6
commit
178ab08fe2
49
test/todo/bug2566.c
Normal file
49
test/todo/bug2566.c
Normal file
@ -0,0 +1,49 @@
|
||||
|
||||
/* Regression test for https://github.com/cc65/cc65/issues/2566
|
||||
*
|
||||
* The issue was introduced in an innocious-looking commit back in 2020:
|
||||
*
|
||||
* https://github.com/cc65/cc65/commit/c3a6b399456937093eda9994f19b7f722731528d
|
||||
*
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
typedef struct {
|
||||
unsigned long Field1;
|
||||
unsigned long Field2;
|
||||
} RecordType;
|
||||
|
||||
typedef struct {
|
||||
char dummy; // -- Offsets the Rec field by 1 byte.
|
||||
RecordType Rec;
|
||||
} StructTypeA;
|
||||
|
||||
typedef struct {
|
||||
RecordType Rec;
|
||||
} StructTypeB;
|
||||
|
||||
int main(void)
|
||||
{
|
||||
StructTypeA A, *Aptr;
|
||||
StructTypeB B;
|
||||
bool ok;
|
||||
|
||||
A.Rec.Field1 = 0x11111111;
|
||||
A.Rec.Field2 = 0x22222222;
|
||||
|
||||
Aptr = &A;
|
||||
B.Rec = Aptr->Rec;
|
||||
|
||||
/* These print statements give some clues as to what's going on. */
|
||||
/*
|
||||
printf("A.Rec: %lx, %lx\n", A.Rec.Field1, A.Rec.Field2);
|
||||
printf("B.Rec: %lx, %lx\n", B.Rec.Field1, B.Rec.Field2);
|
||||
*/
|
||||
|
||||
ok = (A.Rec.Field1 == B.Rec.Field1 && A.Rec.Field2 == B.Rec.Field2);
|
||||
|
||||
return ok ? EXIT_SUCCESS : EXIT_FAILURE;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user