From 0d05848a9724ca7f5ca35994d02aecc5b4d87846 Mon Sep 17 00:00:00 2001 From: Robert Zakrzewski Date: Fri, 21 Jun 2024 16:42:21 +0200 Subject: [PATCH] Refactor type_f16|32|128 functions. Common type_kind() --- src/type_.rs | 52 +++++----------------------------------------------- 1 file changed, 5 insertions(+), 47 deletions(-) diff --git a/src/type_.rs b/src/type_.rs index 7bcc71e581d..765d0df6a08 100644 --- a/src/type_.rs +++ b/src/type_.rs @@ -125,47 +125,32 @@ impl<'gcc, 'tcx> BaseTypeMethods<'tcx> for CodegenCx<'gcc, 'tcx> { self.isize_type } - #[cfg(feature = "master")] fn type_f16(&self) -> Type<'gcc> { + #[cfg(feature = "master")] if self.supports_f16_type { return self.context.new_c_type(CType::Float16); } - unimplemented!("f16") - } - - #[cfg(not(feature = "master"))] - fn type_f16(&self) -> Type<'gcc> { - unimplemented!("f16") + bug!("unsupported float width 16") } - #[cfg(feature = "master")] fn type_f32(&self) -> Type<'gcc> { + #[cfg(feature = "master")] if self.supports_f32_type { return self.context.new_c_type(CType::Float32); } self.float_type } - #[cfg(not(feature = "master"))] - fn type_f32(&self) -> Type<'gcc> { - self.float_type - } - fn type_f64(&self) -> Type<'gcc> { self.double_type } - #[cfg(feature = "master")] fn type_f128(&self) -> Type<'gcc> { + #[cfg(feature = "master")] if self.supports_f128_type { return self.context.new_c_type(CType::Float128); } - unimplemented!("f128") - } - - #[cfg(not(feature = "master"))] - fn type_f128(&self) -> Type<'gcc> { - unimplemented!("f128") + bug!("unsupported float width 128") } fn type_func(&self, params: &[Type<'gcc>], return_type: Type<'gcc>) -> Type<'gcc> { @@ -193,7 +178,6 @@ impl<'gcc, 'tcx> BaseTypeMethods<'tcx> for CodegenCx<'gcc, 'tcx> { typ } - #[cfg(feature = "master")] fn type_kind(&self, typ: Type<'gcc>) -> TypeKind { if self.is_int_type_or_bool(typ) { TypeKind::Integer @@ -227,32 +211,6 @@ impl<'gcc, 'tcx> BaseTypeMethods<'tcx> for CodegenCx<'gcc, 'tcx> { } } - #[cfg(not(feature = "master"))] - fn type_kind(&self, typ: Type<'gcc>) -> TypeKind { - if self.is_int_type_or_bool(typ) { - TypeKind::Integer - } else if typ.is_compatible_with(self.float_type) { - TypeKind::Float - } else if typ.is_compatible_with(self.double_type) { - TypeKind::Double - } else if typ.is_vector() { - TypeKind::Vector - } else if typ.get_pointee().is_some() { - TypeKind::Pointer - } else if typ.dyncast_array().is_some() { - TypeKind::Array - } else if typ.is_struct().is_some() { - TypeKind::Struct - } else if typ.dyncast_function_ptr_type().is_some() { - TypeKind::Function - } else if typ == self.type_void() { - TypeKind::Void - } else { - // TODO(antoyo): support other types. - unimplemented!(); - } - } - fn type_ptr(&self) -> Type<'gcc> { self.type_ptr_to(self.type_void()) }