Comments (7)
Thanks for the clear explanation @danielhenrymantilla !
it needs to re-emit the given definition, which contradicts a derive implementation
This is a bit annoying. ReprC
is not that similar with other traits that are easy to derive - it needs to modify the definition of struct to add repr annotation. Proc macro might be a better way in this regard.
from safer_ffi.
This situation will be improved soon when I move to total proc-macro implementations. In the meantime, moving the #[repr(...)]
before other attributes (except for #[derive_ReprC]
) ought to work 🙂
from safer_ffi.
Like so?
#[repr(i32)]
#[derive(PartialEq)]
#[derive_ReprC]
pub enum Fmi2Status {
Fmi2OK,
Fmi2Warning,
Fmi2Discard,
Fmi2Error,
Fmi2Fatal,
Fmi2Pending,
}
This also came to my mind, but I get the error:
error: macro attributes must be placed before `#[derive]`
--> src\lib.rs:64:1
|
64 | #[derive_ReprC]
| ^^^^^^^^^^^^^^^
By the way, great work on the module :)
from safer_ffi.
Almost there 😄 :
#[derive_ReprC] // needs to be before the derives
#[repr(i32)] // needs to be the first attribute derive_ReprC sees (until I fix that)
#[derive(…)]
enum …
from safer_ffi.
Thank you that solved the issue, I could have sworn I already tried this 😆
from safer_ffi.
How about making ReprC
trait derive-able like this?
from safer_ffi.
@waynexia Yeah, that might probably be doable once we perform the shift to fully procedural implementations; the crate started using macro_rules!
macros, as in:
#[derive_ReprC]
struct Foo { x: i32 }
// becomes:
ReprC! {
struct Foo { x: i32 }
}
and the latter, since it was supposed to also be a standalone-usable public macro, it needs to re-emit the given definition, which contradicts a derive
implementation (which mustn't re-emit the given input, lest it appear twice, conflicting with one another).
Your suggestion would thus be covered by:
-
The idea there is that there could be two approaches:
#[derive(ReprC)] #[repr(C)] // <- error if missing repr struct …
or:
#[safer_ffi::repr(C)] // <- the attribute attaches its own repr struct …
- The latter still "suffers" from the ordering issues mentioned in this very issue, but would be the more flexible approach, by allowing the attribute to attach
repr
, or other such attributes (should there appear more in the future), in a rather API-encapsulated way. That is, it would be the more future-proof approach. But we'll see what we end uo going for
- The latter still "suffers" from the ordering issues mentioned in this very issue, but would be the more flexible approach, by allowing the attribute to attach
from safer_ffi.
Related Issues (20)
- Specifying `[[bin]]` with required features should be a required instruction HOT 1
- Quickstart `crate-type` `lib` seems documented too optional
- Trivial example requires `python-headers` feature to build HOT 2
- No `DOXYGEN` def yields incorrect enum definition HOT 1
- Missing `Clone` impl for `repr_c::Box` (and friends?)
- VS code complains non snake case
- Generated Clone implementation triggers clippy lint about being incorrect for a Copy type HOT 4
- Allow disabling dependency on `inventory v0.1` HOT 2
- Macro ambiguity on nightly: `std::cfg_match` vs `crate::utils::macros::cfg_match` HOT 1
- Conditional proc-macros HOT 2
- How does `safer_ffi` avoid aliasing rule problem? HOT 3
- Compatibility with C++ vector HOT 2
- Handle non-panic Tokio task termination
- no_libc feature?
- C# headers are `public`, when `internal` visibility most likely suffices
- No tag or release for v0.1.5 HOT 1
- Feature Request: Generate rust fn and struct declarations instead of C headers HOT 1
- Python example? HOT 1
- Feature request: serde Serialize and Deserialize support for repr_c::String and repr_c::Vec
- Inconsistent MSRV user guide HOT 1
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 safer_ffi.