aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/c.c
Commit message (Collapse)AuthorAgeFilesLines
* frontend: GNU statement expressions lemon14 days1-33/+55
|
* c.c static eval2ext lemon14 days1-1/+1
|
* frontend: allow folding some non constant expressions as a GNU extension lemon14 days1-14/+29
| | | | And also permit zero size objects
* c: fix some more static initializer edge cases lemon14 days1-7/+13
|
* c: fix complex assignment lemon2026-04-181-3/+1
|
* c: for undeclared function calls, put implicit decl in toplevel lemon2026-04-181-0/+5
| | | | To avoid repeated warnings
* c: fix some compatible type declarations lemon2026-04-181-17/+7
| | | | | | | | | | | When K&R prototypes are present, definition of compatible types and composite types becomes recursive. For example `int f(int (*)())` should be compatible with `int f(int (*)(int))` etc
* support extern inline "definitions" lemon2026-04-171-1/+0
|
* c: fix using array as condition value lemon2026-04-171-2/+2
| | | | Decays to pointer
* revert cbf1018b21e and actual fix lemon2026-04-141-3/+10
| | | | | Actually that check was OK. The issue was in isnullpo(), not detecting the folded `(void*)0`
* c: allow nested aggregate with flexible array member lemon2026-04-141-2/+4
|
* c: fix type of `<unsigned> /= <float>` lemon2026-04-141-2/+5
| | | | | | Would wrongly generate `udiv` and fail later in the backend. Should add a IR sanity checks pass to catch e.g. unsigned operations being used with floating point classes.
* c: make type of conditional expr with pointers match non void pointer lemon2026-04-141-1/+1
| | | | | | | | | | | | | | | | Here's what the C standard[1] says about the conditional operator: ``` if one operand is a null pointer constant, the result has the type of the other operand; otherwise, one operand is a pointer to void or a qualified version of void, in which case the result type is a pointer to an appropriately qualified version of void. `` But actually, some codebases rely on things like 'x ? &foo.memb : NULL' to have the type of `&foo.memb`, and not `void *`... [1]: ISO/IEC 9899:TC3 ยง6.5.15
* cpp: concat 123 ## . lemon2026-04-141-1/+2
|
* c: implement explicit cast complex -> scalar lemon2026-04-131-3/+7
|
* c: match class, not typetag, for libgcc stubs lemon2026-04-131-1/+1
|
* C99 complex types MVP lemon2026-04-131-38/+356
| | | | | | | | | Missing: static eval of complex values, Silly inefficient implementation of equality comparisons between them The whole thing is pretty inefficient without proper aggregate mem2reg anyway
* frontend: accept zero size arrays and empty aggregates lemon2026-04-131-23/+19
| | | | | | GNU extension. Previously was overloading arraylength==0 to mean unsized array, now they are distinct with the type flag TFUNKNOWN marking unsized arrays & aggregates.
* frontend: always narrow assignment expression used as value lemon2026-04-111-2/+2
|
* c: fix bitfields in unions lemon2026-04-101-4/+6
|
* IR: emit inline function standalone bodies lazily lemon2026-03-231-5/+12
| | | | | | | If a function is stashed for inlining and inlined in all of its callsites or unused, it never ends up in the object file. If any symbol reference to it is emitted, then it must be de-inlined (rematerialized), and this is done near the end before emitting the actual object file.
* c: __attribute__ after declarator lemon2026-03-231-0/+1
|
* c: __attribute__ in more places lemon2026-03-231-0/+2
|
* c: remove inline 'backing' type tag for enums lemon2026-03-231-1/+0
| | | | | | | | | | It was meant as a micro-optimization but actually keeping it in sync was annoying. This for example was broken: ``` extern enum foo { ... } g_foo; enum foo g_foo; ```
* style: change uvlong -> u64int, vlong -> s64int lemon2026-03-221-16/+16
| | | | | Is much nicer. I don't know whether I want to do it for the other int types too. char and uchar are fine as bytes. u/short -> u/s16int, maybe.
* IR: add 3rd operand to Instr lemon2026-03-221-3/+3
| | | | | The motivation is for aarch64 msub/madd instrs, for isel to produce. But it should be useful for other things too.
* Rework handling of predefined macros. lemon2026-03-211-3/+3
| | | | And add some GCC predefs like __SIZE_TYPE__, __LONG_SIZE__, etc
* c: fix crash with dead code in condexpr lemon2026-03-201-1/+2
|
* c: better preserve source location in some cases lemon2026-03-201-2/+4
|
* io: make -w suppress notes too lemon2026-03-201-6/+6
|
* c: fix isboollike() for phis lemon2026-03-191-2/+3
|
* c: fix qualifiers for array declarators lemon2026-03-191-7/+10
| | | | | | `const int x[]` was being treated as `const int x[const]`, which is wrong, and matters when `x` is a function parameter that really decays to a pointer (`int const *const x`)
* ir: do not always try to put small literals in .text lemon2026-03-191-3/+3
| | | | | OpenBSD enforces read xor execute (XOM) even in x86-64. Not aware of any other platforms that do this.
* c: remove unused initialization of decl.align lemon2026-03-191-3/+3
| | | | | The intent is for _Alignas declarations but those aren't implemented yet. And initializing that field in declarator() can mess with .sym.
* c: fix edge cases with zero sized bitfields and static initializers lemon2026-03-181-7/+6
|
* Refactor: use typedefs and CamelCase for aggregate types lemon2026-03-181-498/+502
| | | | Looks nicer
* Refactor: move some utils from antcc.h to their own headers lemon2026-03-171-0/+1
|
* REFACTOR: finish renaming lemon2026-03-171-4/+4
|
* REFACTOR: move sources to src/ lemon2026-03-171-0/+4772