-
Notifications
You must be signed in to change notification settings - Fork 321
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merge generic tag enums #784
Comments
Chiming in to say that I'd like this for results too, as well as better names for tags in general (though that may be another PR): use std::marker::PhantomData;
#[repr(C)]
#[derive(Debug)]
pub struct Vec<T: Sized> {
ptr: *const T,
len: usize,
capacity: usize,
_marker: PhantomData<T>,
}
#[repr(C)]
pub struct Error(Vec<u8>);
#[repr(C)]
pub enum Result<T> {
Ok(T),
Err(Error),
}
pub type I32Result = Result<i32>;
pub type U32Result = Result<u32>;
#[no_mangle]
pub unsafe extern "C" fn iresult() -> I32Result {
I32Result::Ok(42)
}
#[no_mangle]
pub unsafe extern "C" fn uresult() -> U32Result {
I32Result::Ok(42)
} Doing #include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>
typedef struct Vec_u8 {
const uint8_t *ptr;
uintptr_t len;
uintptr_t capacity;
} Vec_u8;
typedef struct Error {
struct Vec_u8 _0;
} Error;
typedef enum Result_i32_Tag {
Ok_i32,
Err_i32,
} Result_i32_Tag;
typedef struct Result_i32 {
Result_i32_Tag tag;
union {
struct {
int32_t ok;
};
struct {
struct Error err;
};
};
} Result_i32;
typedef struct Result_i32 I32Result;
typedef enum Result_u32_Tag {
Ok_u32,
Err_u32,
} Result_u32_Tag;
typedef struct Result_u32 {
Result_u32_Tag tag;
union {
struct {
uint32_t ok;
};
struct {
struct Error err;
};
};
} Result_u32;
typedef struct Result_u32 U32Result;
I32Result iresult(void);
U32Result uresult(void); Here, there are two problems:
Anyway, point 1 is showing that I'd love to have this feature too. Your PR looks good to me! |
Hey there! |
At the moment, when a generic tagged enum is used, a tag enum is generated for every specialization of the generic. However, the possible tags and their values do not change based on the generic parameters, so these tag enums are identical.
There should be an option to merge these enums into one that ignores the generics, perhaps
enum.merge_generic_tag
.This would shorten types and improve readability for common use cases such as result types, where the tag is often checked manually after a function call, especially in cases where the generic types are long.
Example
Rust code:
Current output:
Ideal output:
The text was updated successfully, but these errors were encountered: