mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-06-30 08:18:30 +00:00
Add chibicc
This program popped up on Hacker News recently. It's the only modern compiler I've ever seen that doesn't have dependencies and is easily modified. So I added all of the missing GNU extensions I like to use which means it might be possible soon to build on non-Linux and have third party not vendor gcc binaries.
This commit is contained in:
parent
e44a0cf6f8
commit
8da931a7f6
298 changed files with 19493 additions and 11950 deletions
379
third_party/chibicc/test/struct_test.c
vendored
Normal file
379
third_party/chibicc/test/struct_test.c
vendored
Normal file
|
@ -0,0 +1,379 @@
|
|||
#include "third_party/chibicc/test/test.h"
|
||||
|
||||
int main() {
|
||||
ASSERT(1, ({
|
||||
struct {
|
||||
int a;
|
||||
int b;
|
||||
} x;
|
||||
x.a = 1;
|
||||
x.b = 2;
|
||||
x.a;
|
||||
}));
|
||||
ASSERT(2, ({
|
||||
struct {
|
||||
int a;
|
||||
int b;
|
||||
} x;
|
||||
x.a = 1;
|
||||
x.b = 2;
|
||||
x.b;
|
||||
}));
|
||||
ASSERT(1, ({
|
||||
struct {
|
||||
char a;
|
||||
int b;
|
||||
char c;
|
||||
} x;
|
||||
x.a = 1;
|
||||
x.b = 2;
|
||||
x.c = 3;
|
||||
x.a;
|
||||
}));
|
||||
ASSERT(2, ({
|
||||
struct {
|
||||
char a;
|
||||
int b;
|
||||
char c;
|
||||
} x;
|
||||
x.b = 1;
|
||||
x.b = 2;
|
||||
x.c = 3;
|
||||
x.b;
|
||||
}));
|
||||
ASSERT(3, ({
|
||||
struct {
|
||||
char a;
|
||||
int b;
|
||||
char c;
|
||||
} x;
|
||||
x.a = 1;
|
||||
x.b = 2;
|
||||
x.c = 3;
|
||||
x.c;
|
||||
}));
|
||||
|
||||
ASSERT(0, ({
|
||||
struct {
|
||||
char a;
|
||||
char b;
|
||||
} x[3];
|
||||
char *p = x;
|
||||
p[0] = 0;
|
||||
x[0].a;
|
||||
}));
|
||||
ASSERT(1, ({
|
||||
struct {
|
||||
char a;
|
||||
char b;
|
||||
} x[3];
|
||||
char *p = x;
|
||||
p[1] = 1;
|
||||
x[0].b;
|
||||
}));
|
||||
ASSERT(2, ({
|
||||
struct {
|
||||
char a;
|
||||
char b;
|
||||
} x[3];
|
||||
char *p = x;
|
||||
p[2] = 2;
|
||||
x[1].a;
|
||||
}));
|
||||
ASSERT(3, ({
|
||||
struct {
|
||||
char a;
|
||||
char b;
|
||||
} x[3];
|
||||
char *p = x;
|
||||
p[3] = 3;
|
||||
x[1].b;
|
||||
}));
|
||||
|
||||
ASSERT(6, ({
|
||||
struct {
|
||||
char a[3];
|
||||
char b[5];
|
||||
} x;
|
||||
char *p = &x;
|
||||
x.a[0] = 6;
|
||||
p[0];
|
||||
}));
|
||||
ASSERT(7, ({
|
||||
struct {
|
||||
char a[3];
|
||||
char b[5];
|
||||
} x;
|
||||
char *p = &x;
|
||||
x.b[0] = 7;
|
||||
p[3];
|
||||
}));
|
||||
|
||||
ASSERT(6, ({
|
||||
struct {
|
||||
struct {
|
||||
char b;
|
||||
} a;
|
||||
} x;
|
||||
x.a.b = 6;
|
||||
x.a.b;
|
||||
}));
|
||||
|
||||
ASSERT(4, ({
|
||||
struct {
|
||||
int a;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(8, ({
|
||||
struct {
|
||||
int a;
|
||||
int b;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(8, ({
|
||||
struct {
|
||||
int a, b;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(12, ({
|
||||
struct {
|
||||
int a[3];
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(16, ({
|
||||
struct {
|
||||
int a;
|
||||
} x[4];
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(24, ({
|
||||
struct {
|
||||
int a[3];
|
||||
} x[2];
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(2, ({
|
||||
struct {
|
||||
char a;
|
||||
char b;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(0, ({
|
||||
struct {
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(8, ({
|
||||
struct {
|
||||
char a;
|
||||
int b;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(8, ({
|
||||
struct {
|
||||
int a;
|
||||
char b;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
|
||||
ASSERT(8, ({
|
||||
struct t {
|
||||
int a;
|
||||
int b;
|
||||
} x;
|
||||
struct t y;
|
||||
sizeof(y);
|
||||
}));
|
||||
ASSERT(8, ({
|
||||
struct t {
|
||||
int a;
|
||||
int b;
|
||||
};
|
||||
struct t y;
|
||||
sizeof(y);
|
||||
}));
|
||||
ASSERT(2, ({
|
||||
struct t {
|
||||
char a[2];
|
||||
};
|
||||
{
|
||||
struct t {
|
||||
char a[4];
|
||||
};
|
||||
}
|
||||
struct t y;
|
||||
sizeof(y);
|
||||
}));
|
||||
ASSERT(3, ({
|
||||
struct t {
|
||||
int x;
|
||||
};
|
||||
int t = 1;
|
||||
struct t y;
|
||||
y.x = 2;
|
||||
t + y.x;
|
||||
}));
|
||||
|
||||
ASSERT(3, ({
|
||||
struct t {
|
||||
char a;
|
||||
} x;
|
||||
struct t *y = &x;
|
||||
x.a = 3;
|
||||
y->a;
|
||||
}));
|
||||
ASSERT(3, ({
|
||||
struct t {
|
||||
char a;
|
||||
} x;
|
||||
struct t *y = &x;
|
||||
y->a = 3;
|
||||
x.a;
|
||||
}));
|
||||
|
||||
ASSERT(3, ({
|
||||
struct {
|
||||
int a, b;
|
||||
} x, y;
|
||||
x.a = 3;
|
||||
y = x;
|
||||
y.a;
|
||||
}));
|
||||
ASSERT(7, ({
|
||||
struct t {
|
||||
int a, b;
|
||||
};
|
||||
struct t x;
|
||||
x.a = 7;
|
||||
struct t y;
|
||||
struct t *z = &y;
|
||||
*z = x;
|
||||
y.a;
|
||||
}));
|
||||
ASSERT(7, ({
|
||||
struct t {
|
||||
int a, b;
|
||||
};
|
||||
struct t x;
|
||||
x.a = 7;
|
||||
struct t y, *p = &x, *q = &y;
|
||||
*q = *p;
|
||||
y.a;
|
||||
}));
|
||||
ASSERT(5, ({
|
||||
struct t {
|
||||
char a, b;
|
||||
} x, y;
|
||||
x.a = 5;
|
||||
y = x;
|
||||
y.a;
|
||||
}));
|
||||
|
||||
ASSERT(3, ({
|
||||
struct {
|
||||
int a, b;
|
||||
} x, y;
|
||||
x.a = 3;
|
||||
y = x;
|
||||
y.a;
|
||||
}));
|
||||
ASSERT(7, ({
|
||||
struct t {
|
||||
int a, b;
|
||||
};
|
||||
struct t x;
|
||||
x.a = 7;
|
||||
struct t y;
|
||||
struct t *z = &y;
|
||||
*z = x;
|
||||
y.a;
|
||||
}));
|
||||
ASSERT(7, ({
|
||||
struct t {
|
||||
int a, b;
|
||||
};
|
||||
struct t x;
|
||||
x.a = 7;
|
||||
struct t y, *p = &x, *q = &y;
|
||||
*q = *p;
|
||||
y.a;
|
||||
}));
|
||||
ASSERT(5, ({
|
||||
struct t {
|
||||
char a, b;
|
||||
} x, y;
|
||||
x.a = 5;
|
||||
y = x;
|
||||
y.a;
|
||||
}));
|
||||
|
||||
ASSERT(8, ({
|
||||
struct t {
|
||||
int a;
|
||||
int b;
|
||||
} x;
|
||||
struct t y;
|
||||
sizeof(y);
|
||||
}));
|
||||
ASSERT(8, ({
|
||||
struct t {
|
||||
int a;
|
||||
int b;
|
||||
};
|
||||
struct t y;
|
||||
sizeof(y);
|
||||
}));
|
||||
|
||||
ASSERT(16, ({
|
||||
struct {
|
||||
char a;
|
||||
long b;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
ASSERT(4, ({
|
||||
struct {
|
||||
char a;
|
||||
short b;
|
||||
} x;
|
||||
sizeof(x);
|
||||
}));
|
||||
|
||||
ASSERT(8, ({
|
||||
struct foo *bar;
|
||||
sizeof(bar);
|
||||
}));
|
||||
ASSERT(4, ({
|
||||
struct T *foo;
|
||||
struct T {
|
||||
int x;
|
||||
};
|
||||
sizeof(struct T);
|
||||
}));
|
||||
ASSERT(1, ({
|
||||
struct T {
|
||||
struct T *next;
|
||||
int x;
|
||||
} a;
|
||||
struct T b;
|
||||
b.x = 1;
|
||||
a.next = &b;
|
||||
a.next->x;
|
||||
}));
|
||||
ASSERT(4, ({
|
||||
typedef struct T T;
|
||||
struct T {
|
||||
int x;
|
||||
};
|
||||
sizeof(T);
|
||||
}));
|
||||
|
||||
return 0;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue