Skip to content

Commit

Permalink
Use extension name as library name, instead of hardcoded 'native.so'
Browse files Browse the repository at this point in the history
  • Loading branch information
timkpaine committed Jan 21, 2024
1 parent 3492c97 commit 35adb70
Showing 1 changed file with 8 additions and 8 deletions.
16 changes: 8 additions & 8 deletions src/module_writer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -508,15 +508,15 @@ fn entry_points_txt(
}

/// Glue code that exposes `lib`.
fn cffi_init_file() -> &'static str {
r#"__all__ = ["lib", "ffi"]
fn cffi_init_file(extension_name: &str) -> String {
format!(r#"__all__ = ["lib", "ffi"]
import os
from .ffi import ffi
lib = ffi.dlopen(os.path.join(os.path.dirname(__file__), 'native.so'))
lib = ffi.dlopen(os.path.join(os.path.dirname(__file__), '{extension_name}.so'))
del os
"#
"#)
}

/// Wraps some boilerplate around error handling when calling python
Expand Down Expand Up @@ -804,13 +804,13 @@ pub fn write_cffi_module(
if editable {
let base_path = python_module.join(&project_layout.extension_name);
fs::create_dir_all(&base_path)?;
let target = base_path.join("native.so");
let target = base_path.join(format!("{extension_name}.so", extension_name=&project_layout.extension_name));
fs::copy(artifact, &target).context(format!(
"Failed to copy {} to {}",
artifact.display(),
target.display()
))?;
File::create(base_path.join("__init__.py"))?.write_all(cffi_init_file().as_bytes())?;
File::create(base_path.join("__init__.py"))?.write_all(cffi_init_file(&project_layout.extension_name).as_bytes())?;
File::create(base_path.join("ffi.py"))?.write_all(cffi_declarations.as_bytes())?;
}

Expand All @@ -836,9 +836,9 @@ pub fn write_cffi_module(
};

if !editable || project_layout.python_module.is_none() {
writer.add_bytes(&module.join("__init__.py"), cffi_init_file().as_bytes())?;
writer.add_bytes(&module.join("__init__.py"), cffi_init_file(&project_layout.extension_name).as_bytes())?;
writer.add_bytes(&module.join("ffi.py"), cffi_declarations.as_bytes())?;
writer.add_file_with_permissions(&module.join("native.so"), artifact, 0o755)?;
writer.add_file_with_permissions(&module.join(format!("{extension_name}.so", extension_name=&project_layout.extension_name)), artifact, 0o755)?;
}

Ok(())
Expand Down

0 comments on commit 35adb70

Please sign in to comment.