Comments (7)
Fixed by 7cd36c1
I now assume that bodyless enum/struct types are already defined, even when they have pointer types.
from ctod.
It does that because in C you can declare an opaque struct in-line:
void f(struct S *s)
{
}
However, in your examples, it should deduce that there is no pointer type, so it has to be defined already and should not emit a type definition.
from ctod.
The example function don't match the actual code, where it is a pointer. But the struct is defined (possibly in another module), so redefining the struct is still wrong.
For sure, redefining the struct inside a nested struct is wrong.
However, this is D. Can you not record which structs may or may not have been defined, and just spit out some struct S
at the end if you hadn't seen it yet?
from ctod.
An option to disable this "struct prototype" feature would probably work too. Most code is going to be consistent in how they use structs.
from ctod.
Just tested by compiling, and it does indeed complain if you redefine the struct within the same module, even to just define as a prototype.
from ctod.
I suppose a future enhancement would be to manage a symbol table to know which symbols have been defined already, but unless you also read all #include
s you still cannot be sure.
from ctod.
Yeah, it's probably not a huge deal, because defining the struct in the module is such a different thing than defining it again in C.
from ctod.
Related Issues (20)
- C code seems to have degenerate parsing time for some construct HOT 3
- lib-tree-sitter-src/makefile is empty HOT 2
- What to do with linkage definitions? HOT 4
- ifndef with definition HOT 1
- for loop with multiple variables with different types doesn't translate well. HOT 5
- `typedef enum { ... } E;` should provide aliases for values HOT 5
- if(arr[idx] == val) adds the .ptr HOT 1
- casts using custom types and parentheses don't turn into cast statements HOT 5
- #defines ending with a comment get the semicolon at the end of the comment HOT 1
- varargs calls would be nice to translate HOT 2
- What to do with `char x[] = "str"` HOT 1
- static array parameters HOT 4
- non-initial float member of union shouldn't be default initialized to 0 HOT 1
- Somehow whole statements are missing HOT 2
- versions vs. enums HOT 3
- Let's talk about macros HOT 3
- bad static array translation HOT 2
- M1(arm) macOS support? HOT 1
- Integers 128bit support HOT 1
- Incorrect translation of array of structs HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from ctod.