From 7684346e8156e4adbaf5029e8eba760e1de3c5cd Mon Sep 17 00:00:00 2001
From: DaniPopes <57450786+DaniPopes@users.noreply.github.com>
Date: Thu, 16 May 2024 03:43:50 +0300
Subject: [PATCH] Fix rustc and clippy warnings (#492)
* Fix most rustc warnings
* Fix clippy warnings
* Abstract LLVMConstArray
* Fix CI
---
.github/workflows/test.yml | 44 ++++++------
Cargo.toml | 11 ++-
.../implementation_typed_pointers.rs | 4 +-
examples/kaleidoscope/main.rs | 3 +-
src/attributes.rs | 8 +--
src/builder.rs | 8 +--
src/context.rs | 9 ++-
src/debug_info.rs | 1 +
src/execution_engine.rs | 4 +-
src/lib.rs | 9 +--
src/memory_buffer.rs | 2 +
src/module.rs | 3 +-
src/object_file.rs | 2 +
src/support/error_handling.rs | 13 ++--
src/support/mod.rs | 7 +-
src/targets.rs | 13 ++--
src/types/array_type.rs | 30 ++++----
src/types/enums.rs | 2 +-
src/types/float_type.rs | 15 ++--
src/types/int_type.rs | 25 ++-----
src/types/mod.rs | 8 ++-
src/types/ptr_type.rs | 15 ++--
src/types/struct_type.rs | 11 +--
src/types/vec_type.rs | 16 ++---
src/values/array_value.rs | 26 ++++++-
src/values/basic_value_use.rs | 6 +-
src/values/float_value.rs | 4 +-
src/values/instruction_value.rs | 26 ++++---
src/values/int_value.rs | 6 +-
src/values/metadata_value.rs | 49 +++++++------
src/values/mod.rs | 2 +-
src/values/vec_value.rs | 7 +-
tests/all/test_attributes.rs | 5 +-
tests/all/test_builder.rs | 19 +++--
tests/all/test_debug_info.rs | 7 +-
tests/all/test_execution_engine.rs | 4 +-
tests/all/test_instruction_conversion.rs | 3 +-
tests/all/test_instruction_values.rs | 43 ++++++-----
tests/all/test_module.rs | 8 +--
tests/all/test_object_file.rs | 18 ++---
tests/all/test_targets.rs | 10 +--
tests/all/test_types.rs | 71 +++++++++++++------
tests/all/test_values.rs | 22 +++---
43 files changed, 309 insertions(+), 290 deletions(-)
diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml
index 16d4affa147..4a07879d3e0 100644
--- a/.github/workflows/test.yml
+++ b/.github/workflows/test.yml
@@ -5,7 +5,7 @@ on: [push, pull_request]
env:
CARGO_TERM_COLOR: always
DOC_LLVM_FEATURE: llvm17-0
- DOC_LLVM_VERSION: '17.0'
+ DOC_LLVM_VERSION: "17.0"
DOC_PATH: target/doc
jobs:
@@ -14,9 +14,9 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Install Rust Stable
- run: rustup toolchain install stable
+ uses: dtolnay/rust-toolchain@stable
- name: Install typos
- run: cargo install typos-cli
+ uses: taiki-e/install-action@typos
- name: Run typos
run: typos .
tests:
@@ -39,22 +39,24 @@ jobs:
- ["15.0", "15-0"]
- ["16.0", "16-0"]
- ["17.0", "17-0"]
- # only use ubuntu-22.04 for llvm 16 and higher
include:
- os: ubuntu-20.04
+ # only use ubuntu-22.04 for llvm 16 and higher
- os: ubuntu-22.04
llvm-version: ["16.0", "16-0"]
- os: ubuntu-22.04
llvm-version: ["17.0", "17-0"]
steps:
- name: Checkout Repo
- uses: actions/checkout@v3
+ uses: actions/checkout@v4
- name: Install LLVM and Clang
uses: KyleMayes/install-llvm-action@v1
with:
version: ${{ matrix.llvm-version[0] }}
- name: llvm-config
run: llvm-config --version --bindir --libdir
+ - name: Install Rust Stable
+ uses: dtolnay/rust-toolchain@stable
- name: Build
run: cargo build --release --features llvm${{ matrix.llvm-version[1] }} --verbose
- name: Run tests
@@ -67,19 +69,19 @@ jobs:
needs: [typos, tests]
if: github.event_name == 'push' && github.ref == 'refs/heads/master'
steps:
- - uses: actions/checkout@v3
- - uses: KyleMayes/install-llvm-action@v1
- with:
- version: ${{ env.DOC_LLVM_VERSION }}
- - name: Install Rust Nightly
- run: rustup toolchain install nightly
- - name: Build Documentation
- run: cargo +nightly doc --features ${{ env.DOC_LLVM_FEATURE }},nightly --verbose
- - name: Doc Index Page Redirection
- run: echo '' > ${{ env.DOC_PATH }}/index.html
- - name: Deploy Documentation
- uses: peaceiris/actions-gh-pages@v3
- with:
- github_token: ${{ secrets.GITHUB_TOKEN }}
- publish_dir: ${{ env.DOC_PATH }}
- force_orphan: true
+ - uses: actions/checkout@v4
+ - uses: KyleMayes/install-llvm-action@v1
+ with:
+ version: ${{ env.DOC_LLVM_VERSION }}
+ - name: Install Rust Nightly
+ uses: dtolnay/rust-toolchain@nightly
+ - name: Build Documentation
+ run: cargo +nightly doc --features ${{ env.DOC_LLVM_FEATURE }},nightly --verbose
+ - name: Doc Index Page Redirection
+ run: echo '' > ${{ env.DOC_PATH }}/index.html
+ - name: Deploy Documentation
+ uses: peaceiris/actions-gh-pages@v3
+ with:
+ github_token: ${{ secrets.GITHUB_TOKEN }}
+ publish_dir: ${{ env.DOC_PATH }}
+ force_orphan: true
diff --git a/Cargo.toml b/Cargo.toml
index 9cd89898cb5..59a906dc9b9 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -13,6 +13,7 @@ edition = "2021"
[features]
default = ["target-all"]
+
# Please update internal_macros::FEATURE_VERSIONS when adding a new LLVM version
llvm4-0 = ["llvm-sys-40"]
llvm5-0 = ["llvm-sys-50"]
@@ -29,6 +30,7 @@ llvm15-0 = ["llvm-sys-150"]
llvm16-0 = ["llvm-sys-160"]
llvm17-0 = ["llvm-sys-170"]
llvm18-0 = ["llvm-sys-180"]
+
# Don't link against LLVM libraries. This is useful if another dependency is
# installing LLVM. See llvm-sys for more details. We can't enable a single
# `no-llvm-linking` feature across the board of llvm versions, as it'll cause
@@ -133,9 +135,8 @@ experimental = ["static-alloc"]
nightly = ["inkwell_internals/nightly"]
[dependencies]
-either = "1.5"
inkwell_internals = { path = "./internal_macros", version = "0.9.0" }
-libc = "0.2"
+
llvm-sys-40 = { package = "llvm-sys", version = "40.4", optional = true }
llvm-sys-50 = { package = "llvm-sys", version = "50.4", optional = true }
llvm-sys-60 = { package = "llvm-sys", version = "60.6", optional = true }
@@ -151,9 +152,13 @@ llvm-sys-150 = { package = "llvm-sys", version = "150.0.3", optional = true }
llvm-sys-160 = { package = "llvm-sys", version = "160.1.0", optional = true }
llvm-sys-170 = { package = "llvm-sys", version = "170.0.1", optional = true }
llvm-sys-180 = { package = "llvm-sys", version = "180.0.0", optional = true }
+
+either = "1.5"
+libc = "0.2"
once_cell = "1.16"
-static-alloc = { version = "0.2", optional = true }
thiserror = "1.0.48"
+
+static-alloc = { version = "0.2", optional = true }
serde = { version = "1.0", default-features = false, features = ["derive"], optional = true }
[dev-dependencies]
diff --git a/examples/kaleidoscope/implementation_typed_pointers.rs b/examples/kaleidoscope/implementation_typed_pointers.rs
index 96ffeb6f233..acf7c0253fb 100644
--- a/examples/kaleidoscope/implementation_typed_pointers.rs
+++ b/examples/kaleidoscope/implementation_typed_pointers.rs
@@ -51,12 +51,10 @@ pub struct LexError {
}
impl LexError {
- #[allow(unused)]
pub fn new(msg: &'static str) -> LexError {
LexError { error: msg, index: 0 }
}
- #[allow(unused)]
pub fn with_index(msg: &'static str, index: usize) -> LexError {
LexError { error: msg, index }
}
@@ -884,7 +882,7 @@ impl<'a, 'ctx> Compiler<'a, 'ctx> {
} => {
let mut old_bindings = Vec::new();
- for &(ref var_name, ref initializer) in variables {
+ for (var_name, initializer) in variables {
let var_name = var_name.as_str();
let initial_val = match *initializer {
diff --git a/examples/kaleidoscope/main.rs b/examples/kaleidoscope/main.rs
index 9e30673e689..ecde85f5bc0 100644
--- a/examples/kaleidoscope/main.rs
+++ b/examples/kaleidoscope/main.rs
@@ -32,8 +32,7 @@ use inkwell::{
use inkwell_internals::llvm_versions;
mod implementation_typed_pointers;
-
-use crate::implementation_typed_pointers::*;
+pub use implementation_typed_pointers::*;
// ======================================================================================
// PROGRAM ==============================================================================
diff --git a/src/attributes.rs b/src/attributes.rs
index 70dec1eb631..ed85374c489 100644
--- a/src/attributes.rs
+++ b/src/attributes.rs
@@ -369,14 +369,10 @@ impl AttributeLoc {
match self {
AttributeLoc::Return => 0,
AttributeLoc::Param(index) => {
- assert!(
- index <= u32::max_value() - 2,
- "Param index must be <= u32::max_value() - 2"
- );
-
+ assert!(index <= u32::MAX - 2, "Param index must be <= u32::MAX - 2");
index + 1
},
- AttributeLoc::Function => u32::max_value(),
+ AttributeLoc::Function => u32::MAX,
}
}
}
diff --git a/src/builder.rs b/src/builder.rs
index 9455134030d..084a3d03e25 100644
--- a/src/builder.rs
+++ b/src/builder.rs
@@ -421,7 +421,7 @@ impl<'ctx> Builder<'ctx> {
///
/// builder.position_at_end(basic_block);
///
- /// let pi = f32_type.const_float(::std::f64::consts::PI);
+ /// let pi = f32_type.const_float(std::f64::consts::PI);
///
/// builder.build_return(Some(&pi)).unwrap();
///
@@ -542,7 +542,7 @@ impl<'ctx> Builder<'ctx> {
///
/// builder.position_at_end(basic_block);
///
- /// let pi = f32_type.const_float(::std::f64::consts::PI);
+ /// let pi = f32_type.const_float(std::f64::consts::PI);
///
/// builder.build_return(Some(&pi)).unwrap();
///
@@ -900,7 +900,7 @@ impl<'ctx> Builder<'ctx> {
///
/// builder.position_at_end(basic_block);
///
- /// let pi = f32_type.const_float(::std::f64::consts::PI);
+ /// let pi = f32_type.const_float(std::f64::consts::PI);
///
/// builder.build_return(Some(&pi)).unwrap();
///
@@ -3390,7 +3390,7 @@ impl<'ctx> Builder<'ctx> {
feature = "llvm17-0",
feature = "llvm18-0"
)))]
- if ptr.get_type().get_element_type().to_basic_type_enum() != cmp.get_type() {
+ if ptr.get_type().get_element_type().as_basic_type_enum() != cmp.get_type() {
return Err(BuilderError::PointeeTypeMismatch(
"The pointer does not point to an element of the value type.",
));
diff --git a/src/context.rs b/src/context.rs
index d8043df6272..041a4aee760 100644
--- a/src/context.rs
+++ b/src/context.rs
@@ -21,10 +21,11 @@ use llvm_sys::core::{
LLVMCreateStringAttribute, LLVMDoubleTypeInContext, LLVMFP128TypeInContext, LLVMFloatTypeInContext,
LLVMGetGlobalContext, LLVMGetMDKindIDInContext, LLVMHalfTypeInContext, LLVMInsertBasicBlockInContext,
LLVMInt16TypeInContext, LLVMInt1TypeInContext, LLVMInt32TypeInContext, LLVMInt64TypeInContext,
- LLVMInt8TypeInContext, LLVMIntTypeInContext, LLVMMDNodeInContext, LLVMMDStringInContext,
- LLVMModuleCreateWithNameInContext, LLVMPPCFP128TypeInContext, LLVMStructCreateNamed, LLVMStructTypeInContext,
- LLVMVoidTypeInContext, LLVMX86FP80TypeInContext,
+ LLVMInt8TypeInContext, LLVMIntTypeInContext, LLVMModuleCreateWithNameInContext, LLVMPPCFP128TypeInContext,
+ LLVMStructCreateNamed, LLVMStructTypeInContext, LLVMVoidTypeInContext, LLVMX86FP80TypeInContext,
};
+#[allow(deprecated)]
+use llvm_sys::core::{LLVMMDNodeInContext, LLVMMDStringInContext};
use llvm_sys::ir_reader::LLVMParseIRInContext;
use llvm_sys::prelude::{LLVMContextRef, LLVMDiagnosticInfoRef, LLVMTypeRef, LLVMValueRef};
use llvm_sys::target::{LLVMIntPtrTypeForASInContext, LLVMIntPtrTypeInContext};
@@ -328,6 +329,7 @@ impl ContextImpl {
}
}
+ #[allow(deprecated)]
fn metadata_node<'ctx>(&self, values: &[BasicMetadataValueEnum<'ctx>]) -> MetadataValue<'ctx> {
let mut tuple_values: Vec = values.iter().map(|val| val.as_value_ref()).collect();
unsafe {
@@ -339,6 +341,7 @@ impl ContextImpl {
}
}
+ #[allow(deprecated)]
fn metadata_string<'ctx>(&self, string: &str) -> MetadataValue<'ctx> {
let c_string = to_c_str(string);
diff --git a/src/debug_info.rs b/src/debug_info.rs
index eda78402231..678db68060e 100644
--- a/src/debug_info.rs
+++ b/src/debug_info.rs
@@ -167,6 +167,7 @@ impl<'ctx> DIScope<'ctx> {
/// Specific scopes (i.e. `DILexicalBlock`) can be turned into a `DIScope` with the
/// `AsDIScope::as_debug_info_scope` trait method.
pub trait AsDIScope<'ctx> {
+ #[allow(clippy::wrong_self_convention)]
fn as_debug_info_scope(self) -> DIScope<'ctx>;
}
diff --git a/src/execution_engine.rs b/src/execution_engine.rs
index f0cb1a5a8ec..1f032782795 100644
--- a/src/execution_engine.rs
+++ b/src/execution_engine.rs
@@ -406,7 +406,7 @@ impl<'ctx> ExecutionEngine<'ctx> {
let cstring_args: Vec<_> = args.iter().map(|&arg| to_c_str(arg)).collect();
let raw_args: Vec<*const _> = cstring_args.iter().map(|arg| arg.as_ptr()).collect();
- let environment_variables = vec![]; // TODO: Support envp. Likely needs to be null terminated
+ let environment_variables = []; // TODO: Support envp. Likely needs to be null terminated
LLVMRunFunctionAsMain(
self.execution_engine_inner(),
@@ -475,7 +475,7 @@ impl Deref for ExecEngineInner<'_> {
type Target = LLVMExecutionEngineRef;
fn deref(&self) -> &Self::Target {
- &*self.0
+ &self.0
}
}
diff --git a/src/lib.rs b/src/lib.rs
index bb7c9c1344e..9917f35920e 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -9,6 +9,7 @@
//! * Most functions which take a string slice as input may possibly panic in the unlikely event that a c style string cannot be created based on it. (IE if your slice already has a null byte in it)
#![deny(missing_debug_implementations)]
+#![allow(clippy::missing_safety_doc, clippy::too_many_arguments, clippy::result_unit_err)]
#![cfg_attr(feature = "nightly", feature(doc_cfg))]
#[macro_use]
@@ -147,15 +148,9 @@ assert_unique_used_features! {
///
/// # Remarks
/// See also: https://llvm.org/doxygen/NVPTXBaseInfo_8h_source.html
-#[derive(Debug, PartialEq, Eq, Copy, Clone)]
+#[derive(Debug, PartialEq, Eq, Copy, Clone, Default)]
pub struct AddressSpace(u32);
-impl Default for AddressSpace {
- fn default() -> Self {
- AddressSpace(0)
- }
-}
-
impl From for AddressSpace {
fn from(val: u16) -> Self {
AddressSpace(val as u32)
diff --git a/src/memory_buffer.rs b/src/memory_buffer.rs
index 6d9fc246155..417a3ecb09b 100644
--- a/src/memory_buffer.rs
+++ b/src/memory_buffer.rs
@@ -3,6 +3,7 @@ use llvm_sys::core::{
LLVMCreateMemoryBufferWithMemoryRangeCopy, LLVMCreateMemoryBufferWithSTDIN, LLVMDisposeMemoryBuffer,
LLVMGetBufferSize, LLVMGetBufferStart,
};
+#[allow(deprecated)]
use llvm_sys::object::LLVMCreateObjectFile;
use llvm_sys::prelude::LLVMMemoryBufferRef;
@@ -123,6 +124,7 @@ impl MemoryBuffer {
/// Convert this `MemoryBuffer` into an `ObjectFile`. LLVM does not currently
/// provide any way to determine the cause of error if conversion fails.
pub fn create_object_file(self) -> Result {
+ #[allow(deprecated)]
let object_file = unsafe { LLVMCreateObjectFile(self.memory_buffer) };
forget(self);
diff --git a/src/module.rs b/src/module.rs
index e5e543d81f8..94e9f80053a 100644
--- a/src/module.rs
+++ b/src/module.rs
@@ -849,6 +849,7 @@ impl<'ctx> Module<'ctx> {
}
/// Prints the content of the `Module` to a `String`.
+ #[allow(clippy::inherent_to_string)]
pub fn to_string(&self) -> String {
self.print_to_string().to_string()
}
@@ -1507,7 +1508,7 @@ impl<'ctx> Module<'ctx> {
machine.target_machine,
options.options_ref,
);
- if error == std::ptr::null_mut() {
+ if error.is_null() {
Ok(())
} else {
let message = LLVMGetErrorMessage(error);
diff --git a/src/object_file.rs b/src/object_file.rs
index 87d84d78f42..eb2344f9d24 100644
--- a/src/object_file.rs
+++ b/src/object_file.rs
@@ -1,3 +1,5 @@
+#![allow(deprecated)]
+
use llvm_sys::object::{
LLVMDisposeObjectFile, LLVMDisposeRelocationIterator, LLVMDisposeSectionIterator, LLVMDisposeSymbolIterator,
LLVMGetRelocationOffset, LLVMGetRelocationSymbol, LLVMGetRelocationType, LLVMGetRelocationTypeName,
diff --git a/src/support/error_handling.rs b/src/support/error_handling.rs
index 84d6cf22ce6..f366cfaea21 100644
--- a/src/support/error_handling.rs
+++ b/src/support/error_handling.rs
@@ -10,7 +10,7 @@ use llvm_sys::LLVMDiagnosticSeverity;
// wrap the provided function input ptr into a &CStr somehow
// TODOC: Can be used like this:
// extern "C" fn print_before_exit(msg: *const i8) {
-// let c_str = unsafe { ::std::ffi::CStr::from_ptr(msg) };
+// let c_str = unsafe { std::ffi::CStr::from_ptr(msg) };
//
// eprintln!("LLVM fatally errored: {:?}", c_str);
// }
@@ -42,12 +42,11 @@ impl DiagnosticInfo {
}
pub(crate) fn severity_is_error(&self) -> bool {
- unsafe {
- match LLVMGetDiagInfoSeverity(self.diagnostic_info) {
- LLVMDiagnosticSeverity::LLVMDSError => true,
- _ => false,
- }
- }
+ self.severity() == LLVMDiagnosticSeverity::LLVMDSError
+ }
+
+ fn severity(&self) -> LLVMDiagnosticSeverity {
+ unsafe { LLVMGetDiagInfoSeverity(self.diagnostic_info) }
}
}
diff --git a/src/support/mod.rs b/src/support/mod.rs
index a0852b5903b..0c3941e6a9c 100644
--- a/src/support/mod.rs
+++ b/src/support/mod.rs
@@ -31,6 +31,7 @@ impl LLVMString {
/// as much as possible to save memory since it is allocated by
/// LLVM. It's essentially a `CString` with a custom LLVM
/// deallocator
+ #[allow(clippy::inherent_to_string_shadow_display)]
pub fn to_string(&self) -> String {
(*self).to_string_lossy().into_owned()
}
@@ -135,7 +136,7 @@ pub fn get_llvm_version() -> (u32, u32, u32) {
unsafe { LLVMGetVersion(&mut major, &mut minor, &mut patch) };
- return (major, minor, patch);
+ (major, minor, patch)
}
/// Possible errors that can occur when loading a library
@@ -186,7 +187,7 @@ pub fn search_for_address_of_symbol(symbol: &str) -> Option {
if address.is_null() {
return None;
}
- return Some(address as usize);
+ Some(address as usize)
}
#[test]
@@ -213,7 +214,7 @@ pub fn enable_llvm_pretty_stack_trace() {
/// A) Finds a terminating null byte in the Rust string and can reference it directly like a C string.
///
/// B) Finds no null byte and allocates a new C string based on the input Rust string.
-pub(crate) fn to_c_str<'s>(mut s: &'s str) -> Cow<'s, CStr> {
+pub(crate) fn to_c_str(mut s: &str) -> Cow<'_, CStr> {
if s.is_empty() {
s = "\0";
}
diff --git a/src/targets.rs b/src/targets.rs
index 4f672ddae98..5edc005632a 100644
--- a/src/targets.rs
+++ b/src/targets.rs
@@ -7,13 +7,12 @@ use llvm_sys::target::{
};
use llvm_sys::target_machine::LLVMCreateTargetDataLayout;
use llvm_sys::target_machine::{
- LLVMAddAnalysisPasses, LLVMCodeGenFileType, LLVMCodeGenOptLevel, LLVMCodeModel, LLVMCreateTargetMachine,
- LLVMDisposeTargetMachine, LLVMGetDefaultTargetTriple, LLVMGetFirstTarget, LLVMGetNextTarget,
- LLVMGetTargetDescription, LLVMGetTargetFromName, LLVMGetTargetFromTriple, LLVMGetTargetMachineCPU,
- LLVMGetTargetMachineFeatureString, LLVMGetTargetMachineTarget, LLVMGetTargetMachineTriple, LLVMGetTargetName,
- LLVMRelocMode, LLVMSetTargetMachineAsmVerbosity, LLVMTargetHasAsmBackend, LLVMTargetHasJIT,
- LLVMTargetHasTargetMachine, LLVMTargetMachineEmitToFile, LLVMTargetMachineEmitToMemoryBuffer, LLVMTargetMachineRef,
- LLVMTargetRef,
+ LLVMAddAnalysisPasses, LLVMCodeGenFileType, LLVMCodeModel, LLVMCreateTargetMachine, LLVMDisposeTargetMachine,
+ LLVMGetDefaultTargetTriple, LLVMGetFirstTarget, LLVMGetNextTarget, LLVMGetTargetDescription, LLVMGetTargetFromName,
+ LLVMGetTargetFromTriple, LLVMGetTargetMachineCPU, LLVMGetTargetMachineFeatureString, LLVMGetTargetMachineTarget,
+ LLVMGetTargetMachineTriple, LLVMGetTargetName, LLVMRelocMode, LLVMSetTargetMachineAsmVerbosity,
+ LLVMTargetHasAsmBackend, LLVMTargetHasJIT, LLVMTargetHasTargetMachine, LLVMTargetMachineEmitToFile,
+ LLVMTargetMachineEmitToMemoryBuffer, LLVMTargetMachineRef, LLVMTargetRef,
};
#[llvm_versions(18..)]
use llvm_sys::target_machine::{
diff --git a/src/types/array_type.rs b/src/types/array_type.rs
index ba7172c0f5c..85568f3009c 100644
--- a/src/types/array_type.rs
+++ b/src/types/array_type.rs
@@ -1,12 +1,13 @@
-use llvm_sys::core::{LLVMConstArray, LLVMGetArrayLength};
-use llvm_sys::prelude::{LLVMTypeRef, LLVMValueRef};
+#[allow(deprecated)]
+use llvm_sys::core::LLVMGetArrayLength;
+use llvm_sys::prelude::LLVMTypeRef;
use crate::context::ContextRef;
use crate::support::LLVMString;
use crate::types::enums::BasicMetadataTypeEnum;
use crate::types::traits::AsTypeRef;
use crate::types::{BasicTypeEnum, FunctionType, PointerType, Type};
-use crate::values::{ArrayValue, AsValueRef, IntValue};
+use crate::values::{ArrayValue, IntValue};
use crate::AddressSpace;
use std::fmt::{self, Display};
@@ -158,7 +159,7 @@ impl<'ctx> ArrayType<'ctx> {
self.array_type.array_type(size)
}
- /// Creates a constant `ArrayValue`.
+ /// Creates a constant `ArrayValue` of `ArrayValue`s.
///
/// # Example
/// ```no_run
@@ -173,14 +174,7 @@ impl<'ctx> ArrayType<'ctx> {
/// assert!(f32_array_array.is_const());
/// ```
pub fn const_array(self, values: &[ArrayValue<'ctx>]) -> ArrayValue<'ctx> {
- let mut values: Vec = values.iter().map(|val| val.as_value_ref()).collect();
- unsafe {
- ArrayValue::new(LLVMConstArray(
- self.as_type_ref(),
- values.as_mut_ptr(),
- values.len() as u32,
- ))
- }
+ unsafe { ArrayValue::new_const_array(&self, values) }
}
/// Creates a constant zero value of this `ArrayType`.
@@ -213,7 +207,15 @@ impl<'ctx> ArrayType<'ctx> {
/// assert_eq!(i8_array_type.len(), 3);
/// ```
pub fn len(self) -> u32 {
- unsafe { LLVMGetArrayLength(self.as_type_ref()) }
+ #[allow(deprecated)]
+ unsafe {
+ LLVMGetArrayLength(self.as_type_ref())
+ }
+ }
+
+ /// Returns `true` if this `ArrayType` contains no elements.
+ pub fn is_empty(self) -> bool {
+ self.len() == 0
}
/// Print the definition of an `ArrayType` to `LLVMString`
@@ -272,7 +274,7 @@ impl<'ctx> ArrayType<'ctx> {
/// assert_eq!(i8_array_type.get_element_type().into_int_type(), i8_type);
/// ```
pub fn get_element_type(self) -> BasicTypeEnum<'ctx> {
- self.array_type.get_element_type().to_basic_type_enum()
+ self.array_type.get_element_type().as_basic_type_enum()
}
}
diff --git a/src/types/enums.rs b/src/types/enums.rs
index b800e337155..39460e8c994 100644
--- a/src/types/enums.rs
+++ b/src/types/enums.rs
@@ -265,7 +265,7 @@ impl<'ctx> AnyTypeEnum<'ctx> {
}
/// This will panic if type is a void or function type.
- pub(crate) fn to_basic_type_enum(&self) -> BasicTypeEnum<'ctx> {
+ pub(crate) fn as_basic_type_enum(&self) -> BasicTypeEnum<'ctx> {
unsafe { BasicTypeEnum::new(self.as_type_ref()) }
}
diff --git a/src/types/float_type.rs b/src/types/float_type.rs
index c7612c824a3..b7abe8974b0 100644
--- a/src/types/float_type.rs
+++ b/src/types/float_type.rs
@@ -1,13 +1,13 @@
-use llvm_sys::core::{LLVMConstArray, LLVMConstReal, LLVMConstRealOfStringAndSize};
+use llvm_sys::core::{LLVMConstReal, LLVMConstRealOfStringAndSize};
use llvm_sys::execution_engine::LLVMCreateGenericValueOfFloat;
-use llvm_sys::prelude::{LLVMTypeRef, LLVMValueRef};
+use llvm_sys::prelude::LLVMTypeRef;
use crate::context::ContextRef;
use crate::support::LLVMString;
use crate::types::enums::BasicMetadataTypeEnum;
use crate::types::traits::AsTypeRef;
use crate::types::{ArrayType, FunctionType, PointerType, Type, VectorType};
-use crate::values::{ArrayValue, AsValueRef, FloatValue, GenericValue, IntValue};
+use crate::values::{ArrayValue, FloatValue, GenericValue, IntValue};
use crate::AddressSpace;
use std::fmt::{self, Display};
@@ -304,14 +304,7 @@ impl<'ctx> FloatType<'ctx> {
/// assert!(f32_array.is_const());
/// ```
pub fn const_array(self, values: &[FloatValue<'ctx>]) -> ArrayValue<'ctx> {
- let mut values: Vec = values.iter().map(|val| val.as_value_ref()).collect();
- unsafe {
- ArrayValue::new(LLVMConstArray(
- self.as_type_ref(),
- values.as_mut_ptr(),
- values.len() as u32,
- ))
- }
+ unsafe { ArrayValue::new_const_array(&self, values) }
}
}
diff --git a/src/types/int_type.rs b/src/types/int_type.rs
index a46d6169993..c5867ce0090 100644
--- a/src/types/int_type.rs
+++ b/src/types/int_type.rs
@@ -1,15 +1,14 @@
use llvm_sys::core::{
- LLVMConstAllOnes, LLVMConstArray, LLVMConstInt, LLVMConstIntOfArbitraryPrecision, LLVMConstIntOfStringAndSize,
- LLVMGetIntTypeWidth,
+ LLVMConstAllOnes, LLVMConstInt, LLVMConstIntOfArbitraryPrecision, LLVMConstIntOfStringAndSize, LLVMGetIntTypeWidth,
};
use llvm_sys::execution_engine::LLVMCreateGenericValueOfInt;
-use llvm_sys::prelude::{LLVMTypeRef, LLVMValueRef};
+use llvm_sys::prelude::LLVMTypeRef;
use crate::context::ContextRef;
use crate::support::LLVMString;
use crate::types::traits::AsTypeRef;
use crate::types::{ArrayType, FunctionType, PointerType, Type, VectorType};
-use crate::values::{ArrayValue, AsValueRef, GenericValue, IntValue};
+use crate::values::{ArrayValue, GenericValue, IntValue};
use crate::AddressSpace;
use crate::types::enums::BasicMetadataTypeEnum;
@@ -58,14 +57,7 @@ impl StringRadix {
}
// and all digits must be in the radix' character set
- let mut it = slice.chars();
- match self {
- StringRadix::Binary => it.all(|c| matches!(c, '0'..='1')),
- StringRadix::Octal => it.all(|c| matches!(c, '0'..='7')),
- StringRadix::Decimal => it.all(|c| matches!(c, '0'..='9')),
- StringRadix::Hexadecimal => it.all(|c| matches!(c, '0'..='9' | 'a'..='f' | 'A'..='F')),
- StringRadix::Alphanumeric => it.all(|c| matches!(c, '0'..='9' | 'a'..='z' | 'A'..='Z')),
- }
+ slice.chars().all(|c| c.is_digit(*self as u32))
}
}
@@ -416,14 +408,7 @@ impl<'ctx> IntType<'ctx> {
/// assert!(i8_array.is_const());
/// ```
pub fn const_array(self, values: &[IntValue<'ctx>]) -> ArrayValue<'ctx> {
- let mut values: Vec = values.iter().map(|val| val.as_value_ref()).collect();
- unsafe {
- ArrayValue::new(LLVMConstArray(
- self.as_type_ref(),
- values.as_mut_ptr(),
- values.len() as u32,
- ))
- }
+ unsafe { ArrayValue::new_const_array(&self, values) }
}
}
diff --git a/src/types/mod.rs b/src/types/mod.rs
index de52ca7278f..cb588986b25 100644
--- a/src/types/mod.rs
+++ b/src/types/mod.rs
@@ -38,10 +38,11 @@ pub use crate::types::void_type::VoidType;
#[llvm_versions(12..)]
use llvm_sys::core::LLVMGetPoison;
+#[allow(deprecated)]
+use llvm_sys::core::LLVMArrayType;
use llvm_sys::core::{
- LLVMAlignOf, LLVMArrayType, LLVMConstNull, LLVMConstPointerNull, LLVMFunctionType, LLVMGetElementType,
- LLVMGetTypeContext, LLVMGetTypeKind, LLVMGetUndef, LLVMPointerType, LLVMPrintTypeToString, LLVMSizeOf,
- LLVMTypeIsSized, LLVMVectorType,
+ LLVMAlignOf, LLVMConstNull, LLVMConstPointerNull, LLVMFunctionType, LLVMGetElementType, LLVMGetTypeContext,
+ LLVMGetTypeKind, LLVMGetUndef, LLVMPointerType, LLVMPrintTypeToString, LLVMSizeOf, LLVMTypeIsSized, LLVMVectorType,
};
use llvm_sys::prelude::{LLVMTypeRef, LLVMValueRef};
use llvm_sys::LLVMTypeKind;
@@ -130,6 +131,7 @@ impl<'ctx> Type<'ctx> {
}
}
+ #[allow(deprecated)]
fn array_type(self, size: u32) -> ArrayType<'ctx> {
unsafe { ArrayType::new(LLVMArrayType(self.ty, size)) }
}
diff --git a/src/types/ptr_type.rs b/src/types/ptr_type.rs
index 50d66c11ebc..1ab7dedd76d 100644
--- a/src/types/ptr_type.rs
+++ b/src/types/ptr_type.rs
@@ -1,7 +1,7 @@
+use llvm_sys::core::LLVMGetPointerAddressSpace;
#[llvm_versions(15..)]
use llvm_sys::core::LLVMPointerTypeIsOpaque;
-use llvm_sys::core::{LLVMConstArray, LLVMGetPointerAddressSpace};
-use llvm_sys::prelude::{LLVMTypeRef, LLVMValueRef};
+use llvm_sys::prelude::LLVMTypeRef;
use crate::context::ContextRef;
use crate::support::LLVMString;
@@ -9,7 +9,7 @@ use crate::types::traits::AsTypeRef;
#[llvm_versions(..=14)]
use crate::types::AnyTypeEnum;
use crate::types::{ArrayType, FunctionType, Type, VectorType};
-use crate::values::{ArrayValue, AsValueRef, IntValue, PointerValue};
+use crate::values::{ArrayValue, IntValue, PointerValue};
use crate::AddressSpace;
use crate::types::enums::BasicMetadataTypeEnum;
@@ -368,14 +368,7 @@ impl<'ctx> PointerType<'ctx> {
/// assert!(f32_ptr_array.is_const());
/// ```
pub fn const_array(self, values: &[PointerValue<'ctx>]) -> ArrayValue<'ctx> {
- let mut values: Vec = values.iter().map(|val| val.as_value_ref()).collect();
- unsafe {
- ArrayValue::new(LLVMConstArray(
- self.as_type_ref(),
- values.as_mut_ptr(),
- values.len() as u32,
- ))
- }
+ unsafe { ArrayValue::new_const_array(&self, values) }
}
/// Determine whether this pointer is opaque.
diff --git a/src/types/struct_type.rs b/src/types/struct_type.rs
index b58576b8063..56e24251569 100644
--- a/src/types/struct_type.rs
+++ b/src/types/struct_type.rs
@@ -1,5 +1,5 @@
use llvm_sys::core::{
- LLVMConstArray, LLVMConstNamedStruct, LLVMCountStructElementTypes, LLVMGetStructElementTypes, LLVMGetStructName,
+ LLVMConstNamedStruct, LLVMCountStructElementTypes, LLVMGetStructElementTypes, LLVMGetStructName,
LLVMIsOpaqueStruct, LLVMIsPackedStruct, LLVMStructGetTypeAtIndex, LLVMStructSetBody,
};
use llvm_sys::prelude::{LLVMTypeRef, LLVMValueRef};
@@ -452,14 +452,7 @@ impl<'ctx> StructType<'ctx> {
/// assert!(struct_array.is_const());
/// ```
pub fn const_array(self, values: &[StructValue<'ctx>]) -> ArrayValue<'ctx> {
- let mut values: Vec = values.iter().map(|val| val.as_value_ref()).collect();
- unsafe {
- ArrayValue::new(LLVMConstArray(
- self.as_type_ref(),
- values.as_mut_ptr(),
- values.len() as u32,
- ))
- }
+ unsafe { ArrayValue::new_const_array(&self, values) }
}
}
diff --git a/src/types/vec_type.rs b/src/types/vec_type.rs
index f701e4b1d10..28ccd1f4b70 100644
--- a/src/types/vec_type.rs
+++ b/src/types/vec_type.rs
@@ -1,11 +1,11 @@
-use llvm_sys::core::{LLVMConstArray, LLVMConstVector, LLVMGetVectorSize};
+use llvm_sys::core::{LLVMConstVector, LLVMGetVectorSize};
use llvm_sys::prelude::{LLVMTypeRef, LLVMValueRef};
use crate::context::ContextRef;
use crate::support::LLVMString;
use crate::types::enums::BasicMetadataTypeEnum;
use crate::types::{traits::AsTypeRef, ArrayType, BasicTypeEnum, FunctionType, PointerType, Type};
-use crate::values::{ArrayValue, AsValueRef, BasicValue, IntValue, VectorValue};
+use crate::values::{ArrayValue, BasicValue, IntValue, VectorValue};
use crate::AddressSpace;
use std::fmt::{self, Display};
@@ -184,7 +184,7 @@ impl<'ctx> VectorType<'ctx> {
/// assert_eq!(f32_vector_type.get_element_type().into_float_type(), f32_type);
/// ```
pub fn get_element_type(self) -> BasicTypeEnum<'ctx> {
- self.vec_type.get_element_type().to_basic_type_enum()
+ self.vec_type.get_element_type().as_basic_type_enum()
}
/// Creates a `PointerType` with this `VectorType` for its element type.
@@ -283,15 +283,7 @@ impl<'ctx> VectorType<'ctx> {
/// assert!(f32_array.is_const());
/// ```
pub fn const_array(self, values: &[VectorValue<'ctx>]) -> ArrayValue<'ctx> {
- let mut values: Vec = values.iter().map(|val| val.as_value_ref()).collect();
-
- unsafe {
- ArrayValue::new(LLVMConstArray(
- self.as_type_ref(),
- values.as_mut_ptr(),
- values.len() as u32,
- ))
- }
+ unsafe { ArrayValue::new_const_array(&self, values) }
}
/// Gets a reference to the `Context` this `VectorType` was created in.
diff --git a/src/values/array_value.rs b/src/values/array_value.rs
index 863cad728a8..c6d7c44d6d4 100644
--- a/src/values/array_value.rs
+++ b/src/values/array_value.rs
@@ -1,10 +1,15 @@
+#[llvm_versions(..17)]
+use llvm_sys::core::LLVMConstArray;
+#[llvm_versions(17..)]
+use llvm_sys::core::LLVMConstArray2 as LLVMConstArray;
use llvm_sys::core::{LLVMGetAsString, LLVMIsAConstantArray, LLVMIsAConstantDataArray, LLVMIsConstantString};
+use llvm_sys::prelude::LLVMTypeRef;
use llvm_sys::prelude::LLVMValueRef;
use std::ffi::CStr;
use std::fmt::{self, Display};
-use crate::types::ArrayType;
+use crate::types::{ArrayType, AsTypeRef};
use crate::values::traits::{AnyValue, AsValueRef};
use crate::values::{InstructionValue, Value};
@@ -28,6 +33,25 @@ impl<'ctx> ArrayValue<'ctx> {
}
}
+ /// Creates a new constant `ArrayValue` with the given type and values.
+ ///
+ /// # Safety
+ ///
+ /// `values` must be of the same type as `ty`.
+ pub unsafe fn new_const_array(ty: &T, values: &[V]) -> Self {
+ let values = values.iter().map(V::as_value_ref).collect::>();
+ Self::new_raw_const_array(ty.as_type_ref(), &values)
+ }
+
+ /// Creates a new constant `ArrayValue` with the given type and values.
+ ///
+ /// # Safety
+ ///
+ /// `values` must be of the same type as `ty`.
+ pub unsafe fn new_raw_const_array(ty: LLVMTypeRef, values: &[LLVMValueRef]) -> Self {
+ unsafe { Self::new(LLVMConstArray(ty, values.as_ptr().cast_mut(), values.len() as _)) }
+ }
+
/// Get name of the `ArrayValue`. If the value is a constant, this will
/// return an empty string.
pub fn get_name(&self) -> &CStr {
diff --git a/src/values/basic_value_use.rs b/src/values/basic_value_use.rs
index 4285757f921..32591293770 100644
--- a/src/values/basic_value_use.rs
+++ b/src/values/basic_value_use.rs
@@ -52,7 +52,7 @@ impl<'ctx> BasicValueUse<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
@@ -116,7 +116,7 @@ impl<'ctx> BasicValueUse<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
@@ -155,7 +155,7 @@ impl<'ctx> BasicValueUse<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
diff --git a/src/values/float_value.rs b/src/values/float_value.rs
index f4be7fc04d2..ba396be5186 100644
--- a/src/values/float_value.rs
+++ b/src/values/float_value.rs
@@ -11,7 +11,9 @@ use std::convert::TryFrom;
use std::ffi::CStr;
use std::fmt::{self, Display};
-use crate::types::{AsTypeRef, FloatType};
+#[llvm_versions(..=17)]
+use crate::types::AsTypeRef;
+use crate::types::FloatType;
use crate::values::traits::AsValueRef;
use crate::values::{InstructionValue, IntValue, Value};
use crate::FloatPredicate;
diff --git a/src/values/instruction_value.rs b/src/values/instruction_value.rs
index 2463ba32d7a..3a654261fb7 100644
--- a/src/values/instruction_value.rs
+++ b/src/values/instruction_value.rs
@@ -106,7 +106,7 @@ pub enum InstructionOpcode {
ZExt,
}
-#[derive(Debug, PartialEq, Eq, Copy, Hash)]
+#[derive(Debug, PartialEq, Eq, Clone, Copy, Hash)]
pub struct InstructionValue<'ctx> {
instruction_value: Value<'ctx>,
}
@@ -147,6 +147,12 @@ impl<'ctx> InstructionValue<'ctx> {
}
}
+ /// Creates a clone of this `InstructionValue`, and returns it.
+ /// The clone will have no parent, and no name.
+ pub fn explicit_clone(&self) -> Self {
+ unsafe { Self::new(LLVMInstructionClone(self.as_value_ref())) }
+ }
+
/// Get name of the `InstructionValue`.
pub fn get_name(&self) -> Option<&CStr> {
if self.get_type().is_void_type() {
@@ -481,7 +487,7 @@ impl<'ctx> InstructionValue<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
@@ -544,7 +550,7 @@ impl<'ctx> InstructionValue<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
@@ -648,7 +654,7 @@ impl<'ctx> InstructionValue<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
@@ -694,7 +700,7 @@ impl<'ctx> InstructionValue<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
@@ -761,7 +767,7 @@ impl<'ctx> InstructionValue<'ctx> {
/// builder.position_at_end(basic_block);
///
/// let arg1 = function.get_first_param().unwrap().into_pointer_value();
- /// let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ /// let f32_val = f32_type.const_float(std::f64::consts::PI);
/// let store_instruction = builder.build_store(arg1, f32_val).unwrap();
/// let free_instruction = builder.build_free(arg1).unwrap();
/// let return_instruction = builder.build_return(None).unwrap();
@@ -840,14 +846,6 @@ impl<'ctx> InstructionValue<'ctx> {
}
}
-impl Clone for InstructionValue<'_> {
- /// Creates a clone of this `InstructionValue`, and returns it.
- /// The clone will have no parent, and no name.
- fn clone(&self) -> Self {
- unsafe { InstructionValue::new(LLVMInstructionClone(self.as_value_ref())) }
- }
-}
-
unsafe impl AsValueRef for InstructionValue<'_> {
fn as_value_ref(&self) -> LLVMValueRef {
self.instruction_value.value
diff --git a/src/values/int_value.rs b/src/values/int_value.rs
index c010ef31a57..145a777e951 100644
--- a/src/values/int_value.rs
+++ b/src/values/int_value.rs
@@ -21,11 +21,11 @@ use std::fmt::{self, Display};
use crate::types::FloatType;
use crate::types::{AsTypeRef, IntType, PointerType};
use crate::values::traits::AsValueRef;
-#[llvm_versions(..=16)]
-use crate::values::BasicValueEnum;
#[llvm_versions(..=17)]
use crate::values::FloatValue;
-use crate::values::{BasicValue, InstructionValue, PointerValue, Value};
+#[llvm_versions(..=16)]
+use crate::values::{BasicValue, BasicValueEnum};
+use crate::values::{InstructionValue, PointerValue, Value};
use crate::IntPredicate;
use super::AnyValue;
diff --git a/src/values/metadata_value.rs b/src/values/metadata_value.rs
index 86aeb098089..4a56c36c3f9 100644
--- a/src/values/metadata_value.rs
+++ b/src/values/metadata_value.rs
@@ -16,30 +16,33 @@ use super::AnyValue;
use std::ffi::CStr;
use std::fmt::{self, Display};
-// FIXME: use #[doc(cfg(...))] for this rustdoc comment when it's stabilized:
-// https://github.com/rust-lang/rust/issues/43781
/// Value returned by [`Context::get_kind_id()`](crate::context::Context::get_kind_id)
-/// for the first input string that isn't known. Each LLVM version has a different set of pre-defined metadata kinds.
-#[cfg(feature = "llvm4-0")]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 22;
-#[cfg(feature = "llvm5-0")]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 23;
-#[cfg(any(feature = "llvm6-0", feature = "llvm7-0"))]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 25;
-#[cfg(feature = "llvm8-0")]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 26;
-#[cfg(feature = "llvm9-0")]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 28;
-#[cfg(any(feature = "llvm10-0", feature = "llvm11-0"))]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 30;
-#[cfg(any(feature = "llvm12-0", feature = "llvm13-0", feature = "llvm14-0",))]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 31;
-#[cfg(any(feature = "llvm15-0"))]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 36;
-#[cfg(any(feature = "llvm16-0", feature = "llvm17-0"))]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 39;
-#[cfg(any(feature = "llvm18-0"))]
-pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = 40;
+/// for the first input string that isn't known.
+///
+/// Each LLVM version has a different set of pre-defined metadata kinds.
+pub const FIRST_CUSTOM_METADATA_KIND_ID: u32 = if cfg!(feature = "llvm4-0") {
+ 22
+} else if cfg!(feature = "llvm5-0") {
+ 23
+} else if cfg!(any(feature = "llvm6-0", feature = "llvm7-0")) {
+ 25
+} else if cfg!(feature = "llvm8-0") {
+ 26
+} else if cfg!(feature = "llvm9-0") {
+ 28
+} else if cfg!(any(feature = "llvm10-0", feature = "llvm11-0")) {
+ 30
+} else if cfg!(any(feature = "llvm12-0", feature = "llvm13-0", feature = "llvm14-0",)) {
+ 31
+} else if cfg!(feature = "llvm15-0") {
+ 36
+} else if cfg!(any(feature = "llvm16-0", feature = "llvm17-0")) {
+ 39
+} else if cfg!(feature = "llvm18-0") {
+ 40
+} else {
+ panic!("Unhandled LLVM version")
+};
#[derive(PartialEq, Eq, Clone, Copy, Hash)]
pub struct MetadataValue<'ctx> {
diff --git a/src/values/mod.rs b/src/values/mod.rs
index 1f6cb799f72..d40334fe02c 100644
--- a/src/values/mod.rs
+++ b/src/values/mod.rs
@@ -225,7 +225,7 @@ impl<'ctx> Value<'ctx> {
}
});
- let c_string = section.as_deref().map(to_c_str);
+ let c_string = section.map(to_c_str);
unsafe {
LLVMSetSection(
diff --git a/src/values/vec_value.rs b/src/values/vec_value.rs
index 08c1d181659..d9918a7e861 100644
--- a/src/values/vec_value.rs
+++ b/src/values/vec_value.rs
@@ -1,8 +1,10 @@
#[llvm_versions(..=16)]
use llvm_sys::core::LLVMConstSelect;
+#[allow(deprecated)]
+use llvm_sys::core::LLVMGetElementAsConstant;
use llvm_sys::core::{
- LLVMConstExtractElement, LLVMConstInsertElement, LLVMConstShuffleVector, LLVMGetElementAsConstant,
- LLVMIsAConstantDataVector, LLVMIsAConstantVector,
+ LLVMConstExtractElement, LLVMConstInsertElement, LLVMConstShuffleVector, LLVMIsAConstantDataVector,
+ LLVMIsAConstantVector,
};
use llvm_sys::prelude::LLVMValueRef;
@@ -112,6 +114,7 @@ impl<'ctx> VectorValue<'ctx> {
// TODOC: Value seems to be zero initialized if index out of bounds
// SubType: VectorValue -> BV
+ #[allow(deprecated)]
pub fn get_element_as_constant(self, index: u32) -> BasicValueEnum<'ctx> {
unsafe { BasicValueEnum::new(LLVMGetElementAsConstant(self.as_value_ref(), index)) }
}
diff --git a/tests/all/test_attributes.rs b/tests/all/test_attributes.rs
index 016a1d02f7f..92aab1cf073 100644
--- a/tests/all/test_attributes.rs
+++ b/tests/all/test_attributes.rs
@@ -49,6 +49,8 @@ fn test_type_attribute() {
let context = Context::create();
let kind_id = Attribute::get_named_enum_kind_id("sret");
+ #[allow(deprecated)]
+ let ptr_type = context.i32_type().ptr_type(AddressSpace::default());
let any_types = [
context.i32_type().as_any_type_enum(),
context.f32_type().as_any_type_enum(),
@@ -56,7 +58,7 @@ fn test_type_attribute() {
context.i32_type().vec_type(1).as_any_type_enum(),
context.i32_type().array_type(1).as_any_type_enum(),
context.i32_type().fn_type(&[], false).as_any_type_enum(),
- context.i32_type().ptr_type(AddressSpace::from(5u16)).as_any_type_enum(),
+ ptr_type.as_any_type_enum(),
context
.struct_type(&[context.i32_type().as_basic_type_enum()], false)
.as_any_type_enum(),
@@ -76,6 +78,7 @@ fn test_type_attribute() {
}
#[test]
+#[allow(deprecated)]
fn test_attributes_on_function_values() {
let context = Context::create();
let builder = context.create_builder();
diff --git a/tests/all/test_builder.rs b/tests/all/test_builder.rs
index 2e8528e1f9d..8d22573684a 100644
--- a/tests/all/test_builder.rs
+++ b/tests/all/test_builder.rs
@@ -2,7 +2,6 @@ use inkwell::builder::BuilderError;
use inkwell::context::Context;
use inkwell::{AddressSpace, AtomicOrdering, AtomicRMWBinOp, OptimizationLevel};
-use std::convert::TryFrom;
use std::ptr::null;
#[test]
@@ -19,7 +18,7 @@ fn test_build_call() {
builder.position_at_end(basic_block);
- let pi = f32_type.const_float(::std::f64::consts::PI);
+ let pi = f32_type.const_float(std::f64::consts::PI);
builder.build_return(Some(&pi)).unwrap();
@@ -118,7 +117,7 @@ fn test_build_call() {
feature = "llvm17-0",
feature = "llvm18-0"
))]
- builder.build_indirect_call(fn_type2, load, &[], "call");
+ builder.build_indirect_call(fn_type2, load, &[], "call").unwrap();
builder.build_return(None).unwrap();
assert!(module.verify().is_ok());
@@ -139,7 +138,7 @@ fn test_build_invoke_cleanup_resume() {
builder.position_at_end(basic_block);
- let pi = f32_type.const_float(::std::f64::consts::PI);
+ let pi = f32_type.const_float(std::f64::consts::PI);
builder.build_return(Some(&pi)).unwrap();
@@ -223,7 +222,7 @@ fn test_build_invoke_catch_all() {
builder.position_at_end(basic_block);
- let pi = f32_type.const_float(::std::f64::consts::PI);
+ let pi = f32_type.const_float(std::f64::consts::PI);
builder.build_return(Some(&pi)).unwrap();
@@ -311,7 +310,7 @@ fn landing_pad_filter() {
builder.position_at_end(basic_block);
- let pi = f32_type.const_float(::std::f64::consts::PI);
+ let pi = f32_type.const_float(std::f64::consts::PI);
builder.build_return(Some(&pi)).unwrap();
@@ -1095,7 +1094,7 @@ fn test_insert_value() {
let const_int1 = i32_type.const_int(2, false);
let const_int2 = i32_type.const_int(5, false);
let const_int3 = i32_type.const_int(6, false);
- let const_float = f32_type.const_float(3.14);
+ let const_float = f32_type.const_float(2.0);
assert!(builder
.build_insert_value(array, const_int1, 0, "insert")
@@ -1226,6 +1225,7 @@ fn test_insert_element() {
v = builder
.build_insert_element(v, i8_ty.const_int(3, false), i32_ty.const_int(3, false), "v3")
.unwrap();
+ let _ = v;
builder.build_return(None).unwrap();
@@ -1274,7 +1274,7 @@ fn test_alignment_bytes() {
verify_alignment(alignment);
}
- verify_alignment(u32::max_value());
+ verify_alignment(u32::MAX);
}
#[llvm_versions(8..)]
@@ -1308,7 +1308,6 @@ fn run_memcpy_on<'ctx>(
let len_value = i64_type.const_int(array_len as u64, false);
let element_type = i32_type;
- let array_type = element_type.array_type(array_len as u32);
let array_ptr = builder.build_array_malloc(i32_type, len_value, "array_ptr").unwrap();
// Initialize the array with the values [1, 2, 3, 4]
@@ -1441,7 +1440,6 @@ fn run_memmove_on<'ctx>(
let len_value = i64_type.const_int(array_len as u64, false);
let element_type = i32_type;
- let array_type = element_type.array_type(array_len as u32);
let array_ptr = builder.build_array_malloc(i32_type, len_value, "array_ptr").unwrap();
// Initialize the array with the values [1, 2, 3, 4]
@@ -1575,7 +1573,6 @@ fn run_memset_on<'ctx>(
let len_value = i64_type.const_int(array_len as u64, false);
let element_type = i32_type;
- let array_type = element_type.array_type(array_len as u32);
let array_ptr = builder.build_array_malloc(i32_type, len_value, "array_ptr").unwrap();
let elems_to_copy = 2;
diff --git a/tests/all/test_debug_info.rs b/tests/all/test_debug_info.rs
index 43994d3b453..31408f0ef92 100644
--- a/tests/all/test_debug_info.rs
+++ b/tests/all/test_debug_info.rs
@@ -177,8 +177,8 @@ fn test_struct_with_placeholders() {
)
.unwrap();
- let member_sizes = vec![32, 64, 32, 64];
- let member_types = vec![i32ty, i64ty, f32ty, f64ty];
+ let member_sizes = [32, 64, 32, 64];
+ let member_types = [i32ty, i64ty, f32ty, f64ty];
let member_placeholders = member_types
.iter()
.map(|_ty| unsafe { dibuilder.create_placeholder_derived_type(&context) })
@@ -587,6 +587,7 @@ fn test_reference_types() {
}
#[test]
+#[allow(clippy::single_range_in_vec_init)]
fn test_array_type() {
let context = Context::create();
let module = context.create_module("bin");
@@ -640,7 +641,7 @@ fn test_array_type() {
.unwrap()
.as_type();
- //Smoke test that the array gets created
+ // Smoke test that the array gets created.
dibuilder.create_array_type(di_type, 160, 64, &[(0..20)]);
dibuilder.create_array_type(di_type, 160, 64, &[(0..20), (-1..30), (20..55)]);
diff --git a/tests/all/test_execution_engine.rs b/tests/all/test_execution_engine.rs
index 384a1c2e427..bd056f00003 100644
--- a/tests/all/test_execution_engine.rs
+++ b/tests/all/test_execution_engine.rs
@@ -53,7 +53,6 @@ fn test_jit_execution_engine() {
let context = Context::create();
let module = context.create_module("main_module");
let builder = context.create_builder();
- let i8_type = context.i8_type();
let i32_type = context.i32_type();
#[cfg(not(any(
feature = "llvm15-0",
@@ -61,7 +60,8 @@ fn test_jit_execution_engine() {
feature = "llvm17-0",
feature = "llvm18-0"
)))]
- let i8_ptr_ptr_type = i8_type
+ let i8_ptr_ptr_type = context
+ .i8_type()
.ptr_type(AddressSpace::default())
.ptr_type(AddressSpace::default());
#[cfg(any(
diff --git a/tests/all/test_instruction_conversion.rs b/tests/all/test_instruction_conversion.rs
index a65485ede87..e129e711af9 100644
--- a/tests/all/test_instruction_conversion.rs
+++ b/tests/all/test_instruction_conversion.rs
@@ -110,14 +110,13 @@ fn test_conversion_to_pointer_value() {
builder.position_at_end(basic_block);
// Create a PointerType instruction
- let i64_type = context.i64_type();
#[cfg(not(any(
feature = "llvm15-0",
feature = "llvm16-0",
feature = "llvm17-0",
feature = "llvm18-0"
)))]
- let i64_ptr_type = i64_type.ptr_type(AddressSpace::default());
+ let i64_ptr_type = context.i64_type().ptr_type(AddressSpace::default());
#[cfg(any(
feature = "llvm15-0",
feature = "llvm16-0",
diff --git a/tests/all/test_instruction_values.rs b/tests/all/test_instruction_values.rs
index d3267ca35d9..539bbc1396d 100644
--- a/tests/all/test_instruction_values.rs
+++ b/tests/all/test_instruction_values.rs
@@ -1,5 +1,5 @@
use inkwell::context::Context;
-use inkwell::types::{AnyTypeEnum, AsTypeRef, BasicType};
+use inkwell::types::{AnyTypeEnum, BasicType};
use inkwell::values::{BasicValue, InstructionOpcode::*};
use inkwell::{AddressSpace, AtomicOrdering, AtomicRMWBinOp, FloatPredicate, IntPredicate};
@@ -33,7 +33,7 @@ fn test_operands() {
builder.position_at_end(basic_block);
let arg1 = function.get_first_param().unwrap().into_pointer_value();
- let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ let f32_val = f32_type.const_float(std::f64::consts::PI);
let store_instruction = builder.build_store(arg1, f32_val).unwrap();
let free_instruction = builder.build_free(arg1).unwrap();
let return_instruction = builder.build_return(None).unwrap();
@@ -240,7 +240,7 @@ fn test_get_next_use() {
builder.position_at_end(basic_block);
let arg1 = function.get_first_param().unwrap().into_float_value();
- let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ let f32_val = f32_type.const_float(std::f64::consts::PI);
let add_pi0 = builder.build_float_add(arg1, f32_val, "add_pi").unwrap();
let add_pi1 = builder.build_float_add(add_pi0, f32_val, "add_pi").unwrap();
@@ -294,7 +294,7 @@ fn test_instructions() {
assert!(arg1.get_first_use().is_none());
assert!(arg2.get_first_use().is_none());
- let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ let f32_val = f32_type.const_float(std::f64::consts::PI);
let store_instruction = builder.build_store(arg1, f32_val).unwrap();
let alloca_val = builder.build_alloca(i64_type, "alloca").unwrap();
@@ -351,7 +351,7 @@ fn test_instructions() {
// test instruction cloning
#[allow(clippy::redundant_clone)]
- let instruction_clone = return_instruction.clone();
+ let instruction_clone = return_instruction.explicit_clone();
assert_eq!(instruction_clone.get_opcode(), return_instruction.get_opcode());
assert_ne!(instruction_clone, return_instruction);
@@ -417,16 +417,16 @@ fn test_volatile_atomicrmw_cmpxchg() {
.as_instruction_value()
.unwrap();
- assert_eq!(atomicrmw.get_volatile().unwrap(), false);
- assert_eq!(cmpxchg.get_volatile().unwrap(), false);
+ assert!(!atomicrmw.get_volatile().unwrap());
+ assert!(!cmpxchg.get_volatile().unwrap());
atomicrmw.set_volatile(true).unwrap();
cmpxchg.set_volatile(true).unwrap();
- assert_eq!(atomicrmw.get_volatile().unwrap(), true);
- assert_eq!(cmpxchg.get_volatile().unwrap(), true);
+ assert!(atomicrmw.get_volatile().unwrap());
+ assert!(cmpxchg.get_volatile().unwrap());
atomicrmw.set_volatile(false).unwrap();
cmpxchg.set_volatile(false).unwrap();
- assert_eq!(atomicrmw.get_volatile().unwrap(), false);
- assert_eq!(cmpxchg.get_volatile().unwrap(), false);
+ assert!(!atomicrmw.get_volatile().unwrap());
+ assert!(!cmpxchg.get_volatile().unwrap());
}
#[llvm_versions(..=10)]
@@ -465,7 +465,7 @@ fn test_mem_instructions() {
assert!(arg1.get_first_use().is_none());
assert!(arg2.get_first_use().is_none());
- let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ let f32_val = f32_type.const_float(std::f64::consts::PI);
let store_instruction = builder.build_store(arg1, f32_val).unwrap();
let load = builder.build_load(arg1, "").unwrap();
@@ -543,7 +543,7 @@ fn test_mem_instructions() {
assert!(arg1.get_first_use().is_none());
assert!(arg2.get_first_use().is_none());
- let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ let f32_val = f32_type.const_float(std::f64::consts::PI);
let store_instruction = builder.build_store(arg1, f32_val).unwrap();
#[cfg(any(
@@ -569,16 +569,16 @@ fn test_mem_instructions() {
let load = builder.build_load(f32_type, arg1, "").unwrap();
let load_instruction = load.as_instruction_value().unwrap();
- assert_eq!(store_instruction.get_volatile().unwrap(), false);
- assert_eq!(load_instruction.get_volatile().unwrap(), false);
+ assert!(!store_instruction.get_volatile().unwrap());
+ assert!(!load_instruction.get_volatile().unwrap());
store_instruction.set_volatile(true).unwrap();
load_instruction.set_volatile(true).unwrap();
- assert_eq!(store_instruction.get_volatile().unwrap(), true);
- assert_eq!(load_instruction.get_volatile().unwrap(), true);
+ assert!(store_instruction.get_volatile().unwrap());
+ assert!(load_instruction.get_volatile().unwrap());
store_instruction.set_volatile(false).unwrap();
load_instruction.set_volatile(false).unwrap();
- assert_eq!(store_instruction.get_volatile().unwrap(), false);
- assert_eq!(load_instruction.get_volatile().unwrap(), false);
+ assert!(!store_instruction.get_volatile().unwrap());
+ assert!(!load_instruction.get_volatile().unwrap());
assert_eq!(store_instruction.get_alignment().unwrap(), 4);
assert_eq!(load_instruction.get_alignment().unwrap(), 4);
@@ -640,7 +640,7 @@ fn test_atomic_ordering_mem_instructions() {
assert!(arg1.get_first_use().is_none());
assert!(arg2.get_first_use().is_none());
- let f32_val = f32_type.const_float(::std::f64::consts::PI);
+ let f32_val = f32_type.const_float(std::f64::consts::PI);
let store_instruction = builder.build_store(arg1, f32_val).unwrap();
#[cfg(any(
@@ -774,7 +774,7 @@ fn test_find_instruction_with_name() {
builder.position_at_end(entry);
let var = builder.build_alloca(i32_type, "some_number").unwrap();
- builder.build_store(var, i32_type.const_int(1 as u64, false)).unwrap();
+ builder.build_store(var, i32_type.const_int(1, false)).unwrap();
builder.build_return(None).unwrap();
let block = fn_value.get_first_basic_block().unwrap();
@@ -878,7 +878,6 @@ fn test_or_disjoint_flag() {
let void_type = context.void_type();
let i32_type = context.i32_type();
- let f32_type = context.f32_type();
let fn_type = void_type.fn_type(&[i32_type.into(), i32_type.into()], false);
let builder = context.create_builder();
diff --git a/tests/all/test_module.rs b/tests/all/test_module.rs
index f6e946c97bb..668dc6e6992 100644
--- a/tests/all/test_module.rs
+++ b/tests/all/test_module.rs
@@ -259,12 +259,10 @@ fn test_parse_from_buffer() {
fn test_parse_from_path() {
let context = Context::create();
let garbage_path = Path::new("foo/bar");
- let module_result = Module::parse_bitcode_from_path(&garbage_path, &context);
-
+ let module_result = Module::parse_bitcode_from_path(garbage_path, &context);
assert!(module_result.is_err(), "1");
- let module_result2 = Module::parse_bitcode_from_path(&garbage_path, &context);
-
+ let module_result2 = Module::parse_bitcode_from_path(garbage_path, &context);
assert!(module_result2.is_err(), "2");
let module = context.create_module("mod");
@@ -457,7 +455,7 @@ fn test_metadata_flags() {
assert!(module.get_flag("some_key").is_some());
let f64_type = context.f64_type();
- let f64_val = f64_type.const_float(3.14);
+ let f64_val = f64_type.const_float(std::f64::consts::PI);
assert!(module.get_flag("some_key2").is_none());
diff --git a/tests/all/test_object_file.rs b/tests/all/test_object_file.rs
index cb04ebd82c4..375a1cd3d67 100644
--- a/tests/all/test_object_file.rs
+++ b/tests/all/test_object_file.rs
@@ -20,7 +20,7 @@ fn ptr_sized_int_type<'ctx>(target_machine: &TargetMachine, context: &'ctx Conte
context.ptr_sized_int_type(&target_data, None)
}
-fn apply_target_to_module<'ctx>(target_machine: &TargetMachine, module: &Module) {
+fn apply_target_to_module(target_machine: &TargetMachine, module: &Module) {
module.set_triple(&target_machine.get_triple());
module.set_data_layout(&target_machine.get_target_data().get_data_layout());
}
@@ -56,7 +56,7 @@ fn test_section_iterator() {
let target_machine = get_native_target_machine();
let context = Context::create();
- let mut module = context.create_module("test_section_iterator");
+ let module = context.create_module("test_section_iterator");
let gv_a = module.add_global(context.i8_type(), None, "a");
gv_a.set_initializer(&context.i8_type().const_zero().as_basic_value_enum());
@@ -93,7 +93,7 @@ fn test_section_iterator() {
apply_target_to_module(&target_machine, &module);
let memory_buffer = target_machine
- .write_to_memory_buffer(&mut module, FileType::Object)
+ .write_to_memory_buffer(&module, FileType::Object)
.unwrap();
let object_file = memory_buffer.create_object_file().unwrap();
@@ -140,7 +140,7 @@ fn test_symbol_iterator() {
let target_machine = get_native_target_machine();
let context = Context::create();
- let mut module = context.create_module("test_symbol_iterator");
+ let module = context.create_module("test_symbol_iterator");
module
.add_global(context.i8_type(), None, "a")
.set_initializer(&context.i8_type().const_zero().as_basic_value_enum());
@@ -153,7 +153,7 @@ fn test_symbol_iterator() {
apply_target_to_module(&target_machine, &module);
let memory_buffer = target_machine
- .write_to_memory_buffer(&mut module, FileType::Object)
+ .write_to_memory_buffer(&module, FileType::Object)
.unwrap();
let object_file = memory_buffer.create_object_file().unwrap();
@@ -195,7 +195,7 @@ fn test_reloc_iterator() {
let context = Context::create();
let intptr_t = ptr_sized_int_type(&target_machine, &context);
- let mut module = context.create_module("test_reloc_iterator");
+ let module = context.create_module("test_reloc_iterator");
let x_ptr = module.add_global(context.i8_type(), None, "x").as_pointer_value();
let x_plus_4 = x_ptr.const_to_int(intptr_t).const_add(intptr_t.const_int(4, false));
module.add_global(intptr_t, None, "a").set_initializer(&x_plus_4);
@@ -203,7 +203,7 @@ fn test_reloc_iterator() {
apply_target_to_module(&target_machine, &module);
let memory_buffer = target_machine
- .write_to_memory_buffer(&mut module, FileType::Object)
+ .write_to_memory_buffer(&module, FileType::Object)
.unwrap();
let object_file = memory_buffer.create_object_file().unwrap();
@@ -222,7 +222,7 @@ fn test_section_contains_nul() {
let target_machine = get_native_target_machine();
let context = Context::create();
- let mut module = context.create_module("test_section_iterator");
+ let module = context.create_module("test_section_iterator");
let gv = module.add_global(context.i32_type(), None, "gv");
gv.set_initializer(&context.i32_type().const_int(0xff0000ff, false).as_basic_value_enum());
@@ -231,7 +231,7 @@ fn test_section_contains_nul() {
apply_target_to_module(&target_machine, &module);
let memory_buffer = target_machine
- .write_to_memory_buffer(&mut module, FileType::Object)
+ .write_to_memory_buffer(&module, FileType::Object)
.unwrap();
let object_file = memory_buffer.create_object_file().unwrap();
diff --git a/tests/all/test_targets.rs b/tests/all/test_targets.rs
index 6a64f21c800..dad038bdf73 100644
--- a/tests/all/test_targets.rs
+++ b/tests/all/test_targets.rs
@@ -184,7 +184,7 @@ fn test_default_triple() {
let default_triple = default_triple.as_str().to_string_lossy();
let archs = ["x86_64", "arm64"];
- let has_known_arch = archs.iter().find(|arch| default_triple.starts_with(*arch)).is_some();
+ let has_known_arch = archs.iter().any(|arch| default_triple.starts_with(*arch));
assert!(has_known_arch, "Target triple '{default_triple}' has unknown arch");
let vendors = if cfg!(target_os = "linux") {
@@ -195,7 +195,7 @@ fn test_default_triple() {
vec![]
};
- let has_known_vendor = vendors.iter().find(|vendor| default_triple.contains(*vendor)).is_some();
+ let has_known_vendor = vendors.iter().any(|vendor| default_triple.contains(*vendor));
assert!(has_known_vendor, "Target triple '{default_triple}' has unknown vendor");
let os = [
@@ -204,7 +204,7 @@ fn test_default_triple() {
#[cfg(target_os = "macos")]
"darwin",
];
- let has_known_os = os.iter().find(|os| default_triple.contains(*os)).is_some();
+ let has_known_os = os.iter().any(|os| default_triple.contains(*os));
assert!(has_known_os, "Target triple '{default_triple}' has unknown OS");
// TODO: CFG for other supported major OSes
@@ -310,7 +310,7 @@ fn test_target_data() {
assert_eq!(target_data.element_at_offset(&struct_type, 16), 2);
assert_eq!(target_data.element_at_offset(&struct_type, 24), 3);
assert_eq!(target_data.element_at_offset(&struct_type, 32), 3); // OoB
- assert_eq!(target_data.element_at_offset(&struct_type, ::std::u64::MAX), 3); // OoB; Odd as it seems to cap at max element number
+ assert_eq!(target_data.element_at_offset(&struct_type, u64::MAX), 3); // OoB; Odd as it seems to cap at max element number
assert_eq!(target_data.offset_of_element(&struct_type2, 0), Some(0));
assert_eq!(target_data.offset_of_element(&struct_type2, 1), Some(4));
@@ -325,7 +325,7 @@ fn test_target_data() {
assert_eq!(target_data.element_at_offset(&struct_type2, 8), 2);
assert_eq!(target_data.element_at_offset(&struct_type2, 16), 3);
assert_eq!(target_data.element_at_offset(&struct_type2, 32), 3); // OoB
- assert_eq!(target_data.element_at_offset(&struct_type2, ::std::u64::MAX), 3); // OoB; TODOC: Odd but seems to cap at max element number
+ assert_eq!(target_data.element_at_offset(&struct_type2, u64::MAX), 3); // OoB; TODOC: Odd but seems to cap at max element number
TargetData::create("e-m:e-i64:64-f80:128-n8:16:32:64-S128");
}
diff --git a/tests/all/test_types.rs b/tests/all/test_types.rs
index 378def2e93b..d1e782652fa 100644
--- a/tests/all/test_types.rs
+++ b/tests/all/test_types.rs
@@ -207,22 +207,30 @@ fn sized_types(global_ctx: &Context) {
assert!(!fn_type3.is_sized());
assert!(!fn_type4.is_sized());
- assert!(bool_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(i8_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(i16_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(i32_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(i64_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(i128_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(f16_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(f32_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(f64_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(f80_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(f128_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(ppc_f128_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(struct_type.ptr_type(AddressSpace::default()).is_sized());
- assert!(struct_type2.ptr_type(AddressSpace::default()).is_sized());
- assert!(struct_type3.ptr_type(AddressSpace::default()).is_sized());
- assert!(struct_type4.ptr_type(AddressSpace::default()).is_sized());
+ #[cfg(not(any(
+ feature = "llvm15-0",
+ feature = "llvm16-0",
+ feature = "llvm17-0",
+ feature = "llvm18-0"
+ )))]
+ {
+ assert!(bool_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(i8_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(i16_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(i32_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(i64_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(i128_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(f16_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(f32_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(f64_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(f80_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(f128_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(ppc_f128_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(struct_type.ptr_type(AddressSpace::default()).is_sized());
+ assert!(struct_type2.ptr_type(AddressSpace::default()).is_sized());
+ assert!(struct_type3.ptr_type(AddressSpace::default()).is_sized());
+ assert!(struct_type4.ptr_type(AddressSpace::default()).is_sized());
+ }
assert!(bool_type.array_type(42).is_sized());
assert!(i8_type.array_type(42).is_sized());
@@ -271,8 +279,18 @@ fn sized_types(global_ctx: &Context) {
let opaque_struct_type = global_ctx.opaque_struct_type("opaque");
assert!(!opaque_struct_type.is_sized());
- assert!(opaque_struct_type.ptr_type(AddressSpace::default()).is_sized());
assert!(!opaque_struct_type.array_type(0).is_sized());
+
+ #[cfg(not(any(
+ feature = "llvm15-0",
+ feature = "llvm16-0",
+ feature = "llvm17-0",
+ feature = "llvm18-0"
+ )))]
+ {
+ let opaque_struct_ptr_type = opaque_struct_type.ptr_type(AddressSpace::default());
+ assert!(opaque_struct_ptr_type.is_sized());
+ }
}
#[test]
@@ -424,14 +442,13 @@ fn test_type_copies() {
#[test]
fn test_ptr_type() {
let context = Context::create();
- let i8_type = context.i8_type();
#[cfg(not(any(
feature = "llvm15-0",
feature = "llvm16-0",
feature = "llvm17-0",
feature = "llvm18-0"
)))]
- let ptr_type = i8_type.ptr_type(AddressSpace::default());
+ let ptr_type = context.i8_type().ptr_type(AddressSpace::default());
#[cfg(any(
feature = "llvm15-0",
feature = "llvm16-0",
@@ -455,11 +472,12 @@ fn test_ptr_type() {
feature = "llvm13-0",
feature = "llvm14-0"
))]
- assert_eq!(ptr_type.get_element_type().into_int_type(), i8_type);
+ assert_eq!(ptr_type.get_element_type().into_int_type(), context.i8_type());
// Fn ptr:
let void_type = context.void_type();
let fn_type = void_type.fn_type(&[], false);
+ #[allow(deprecated)]
let fn_ptr_type = fn_type.ptr_type(AddressSpace::default());
#[cfg(any(
@@ -511,6 +529,12 @@ fn test_basic_type_enum() {
&int.vec_type(1),
];
for basic_type in types {
+ #[cfg(not(any(
+ feature = "llvm15-0",
+ feature = "llvm16-0",
+ feature = "llvm17-0",
+ feature = "llvm18-0"
+ )))]
assert_eq!(
basic_type.as_basic_type_enum().ptr_type(addr),
basic_type.ptr_type(addr)
@@ -532,7 +556,7 @@ fn test_no_vector_zero() {
fn test_ptr_address_space() {
let context = Context::create();
- let spaces = [0u32, 1, 2, 3, 4, 5, 6, 1 << 24 - 1];
+ let spaces = [0u32, 1, 2, 3, 4, 5, 6, (1 << 24) - 1];
for index in spaces {
let address_space = AddressSpace::try_from(index).unwrap();
@@ -559,12 +583,13 @@ fn test_ptr_address_space() {
#[llvm_versions(15..)]
#[test]
+#[allow(deprecated)]
fn test_ptr_is_opaque() {
let context = Context::create();
let i32_ptr_type = context.i32_type().ptr_type(AddressSpace::default());
- let ptr_type = context.ptr_type(AddressSpace::default());
-
assert!(i32_ptr_type.is_opaque());
+
+ let ptr_type = context.ptr_type(AddressSpace::default());
assert!(ptr_type.is_opaque());
}
diff --git a/tests/all/test_values.rs b/tests/all/test_values.rs
index aec98e0cdfb..bba39fab60d 100644
--- a/tests/all/test_values.rs
+++ b/tests/all/test_values.rs
@@ -3,8 +3,8 @@ use inkwell::attributes::AttributeLoc;
use inkwell::comdat::ComdatSelectionKind;
use inkwell::context::Context;
use inkwell::module::Linkage::*;
-use inkwell::types::{AnyTypeEnum, BasicType, StringRadix, VectorType};
-use inkwell::values::{AnyValue, BasicValue, InstructionOpcode::*, FIRST_CUSTOM_METADATA_KIND_ID};
+use inkwell::types::{AnyTypeEnum, StringRadix, VectorType};
+use inkwell::values::{AnyValue, InstructionOpcode::*, FIRST_CUSTOM_METADATA_KIND_ID};
use inkwell::{AddressSpace, DLLStorageClass, GlobalVisibility, ThreadLocalMode};
#[llvm_versions(18..)]
@@ -758,7 +758,7 @@ fn test_floats() {
let f128_type = context.f128_type();
let i64_type = context.i32_type();
- let f64_pi = f64_type.const_float(::std::f64::consts::PI);
+ let f64_pi = f64_type.const_float(std::f64::consts::PI);
let f32_pi = f64_pi.const_truncate(f32_type);
let f128_pi = f64_pi.const_extend(f128_type);
@@ -1320,10 +1320,10 @@ fn test_consts() {
assert!(vec_val.is_constant_data_vector());
assert_eq!(bool_val.get_zero_extended_constant(), Some(1));
- assert_eq!(i8_val.get_zero_extended_constant(), Some(u8::max_value() as u64));
- assert_eq!(i16_val.get_zero_extended_constant(), Some(u16::max_value() as u64));
- assert_eq!(i32_val.get_zero_extended_constant(), Some(u32::max_value() as u64));
- assert_eq!(i64_val.get_zero_extended_constant(), Some(u64::max_value() as u64));
+ assert_eq!(i8_val.get_zero_extended_constant(), Some(u8::MAX as u64));
+ assert_eq!(i16_val.get_zero_extended_constant(), Some(u16::MAX as u64));
+ assert_eq!(i32_val.get_zero_extended_constant(), Some(u32::MAX as u64));
+ assert_eq!(i64_val.get_zero_extended_constant(), Some(u64::MAX));
assert_eq!(i128_val.get_zero_extended_constant(), None);
assert_eq!(bool_val.get_sign_extended_constant(), Some(-1));
@@ -1478,7 +1478,9 @@ fn test_non_fn_ptr_called() {
feature = "llvm17-0",
feature = "llvm18-0"
))]
- builder.build_indirect_call(i8_ptr_type.fn_type(&[], false), i8_ptr_param, &[], "call");
+ builder
+ .build_indirect_call(i8_ptr_type.fn_type(&[], false), i8_ptr_param, &[], "call")
+ .unwrap();
builder.build_return(None).unwrap();
assert!(module.verify().is_ok());
@@ -1562,7 +1564,9 @@ fn test_aggregate_returns() {
feature = "llvm17-0",
feature = "llvm18-0"
))]
- builder.build_ptr_diff(i32_ptr_type, ptr_param1, ptr_param2, "diff");
+ builder
+ .build_ptr_diff(i32_ptr_type, ptr_param1, ptr_param2, "diff")
+ .unwrap();
builder
.build_aggregate_return(&[i32_three.into(), i32_seven.into()])
.unwrap();