Simplify the bundles vectors.

After the last commit, they contain `Option<&OperandBundleDef<'a>>` but
the values are always `Some(_)`. This commit removes the needless
`Option` wrapper. This also simplifies the type signatures of
`LLVMRustBuild{Invoke,Call}`, which were relying on the fact that the
represention of `Option<&T>` is the same as `&T` for non-`None` values.
This commit is contained in:
Nicholas Nethercote 2023-06-28 14:09:51 +10:00
parent 81436ebd55
commit 8d7084d65f
2 changed files with 6 additions and 6 deletions

View File

@ -227,7 +227,7 @@ impl<'a, 'll, 'tcx> BuilderMethods<'a, 'tcx> for Builder<'a, 'll, 'tcx> {
let funclet_bundle = funclet.map(|funclet| funclet.bundle()); let funclet_bundle = funclet.map(|funclet| funclet.bundle());
let funclet_bundle = funclet_bundle.as_ref().map(|b| &*b.raw); let funclet_bundle = funclet_bundle.as_ref().map(|b| &*b.raw);
let mut bundles: SmallVec<[_; 2]> = SmallVec::new(); let mut bundles: SmallVec<[_; 2]> = SmallVec::new();
if funclet_bundle.is_some() { if let Some(funclet_bundle) = funclet_bundle {
bundles.push(funclet_bundle); bundles.push(funclet_bundle);
} }
@ -237,7 +237,7 @@ impl<'a, 'll, 'tcx> BuilderMethods<'a, 'tcx> for Builder<'a, 'll, 'tcx> {
// Emit KCFI operand bundle // Emit KCFI operand bundle
let kcfi_bundle = self.kcfi_operand_bundle(fn_attrs, fn_abi, llfn); let kcfi_bundle = self.kcfi_operand_bundle(fn_attrs, fn_abi, llfn);
let kcfi_bundle = kcfi_bundle.as_ref().map(|b| &*b.raw); let kcfi_bundle = kcfi_bundle.as_ref().map(|b| &*b.raw);
if kcfi_bundle.is_some() { if let Some(kcfi_bundle) = kcfi_bundle {
bundles.push(kcfi_bundle); bundles.push(kcfi_bundle);
} }
@ -1195,7 +1195,7 @@ impl<'a, 'll, 'tcx> BuilderMethods<'a, 'tcx> for Builder<'a, 'll, 'tcx> {
let funclet_bundle = funclet.map(|funclet| funclet.bundle()); let funclet_bundle = funclet.map(|funclet| funclet.bundle());
let funclet_bundle = funclet_bundle.as_ref().map(|b| &*b.raw); let funclet_bundle = funclet_bundle.as_ref().map(|b| &*b.raw);
let mut bundles: SmallVec<[_; 2]> = SmallVec::new(); let mut bundles: SmallVec<[_; 2]> = SmallVec::new();
if funclet_bundle.is_some() { if let Some(funclet_bundle) = funclet_bundle {
bundles.push(funclet_bundle); bundles.push(funclet_bundle);
} }
@ -1205,7 +1205,7 @@ impl<'a, 'll, 'tcx> BuilderMethods<'a, 'tcx> for Builder<'a, 'll, 'tcx> {
// Emit KCFI operand bundle // Emit KCFI operand bundle
let kcfi_bundle = self.kcfi_operand_bundle(fn_attrs, fn_abi, llfn); let kcfi_bundle = self.kcfi_operand_bundle(fn_attrs, fn_abi, llfn);
let kcfi_bundle = kcfi_bundle.as_ref().map(|b| &*b.raw); let kcfi_bundle = kcfi_bundle.as_ref().map(|b| &*b.raw);
if kcfi_bundle.is_some() { if let Some(kcfi_bundle) = kcfi_bundle {
bundles.push(kcfi_bundle); bundles.push(kcfi_bundle);
} }

View File

@ -1301,7 +1301,7 @@ extern "C" {
NumArgs: c_uint, NumArgs: c_uint,
Then: &'a BasicBlock, Then: &'a BasicBlock,
Catch: &'a BasicBlock, Catch: &'a BasicBlock,
OpBundles: *const Option<&OperandBundleDef<'a>>, OpBundles: *const &OperandBundleDef<'a>,
NumOpBundles: c_uint, NumOpBundles: c_uint,
Name: *const c_char, Name: *const c_char,
) -> &'a Value; ) -> &'a Value;
@ -1673,7 +1673,7 @@ extern "C" {
Fn: &'a Value, Fn: &'a Value,
Args: *const &'a Value, Args: *const &'a Value,
NumArgs: c_uint, NumArgs: c_uint,
OpBundles: *const Option<&OperandBundleDef<'a>>, OpBundles: *const &OperandBundleDef<'a>,
NumOpBundles: c_uint, NumOpBundles: c_uint,
) -> &'a Value; ) -> &'a Value;
pub fn LLVMRustBuildMemCpy<'a>( pub fn LLVMRustBuildMemCpy<'a>(