Struct python_packaging::resource::PythonExtensionModule
source · pub struct PythonExtensionModule {
pub name: String,
pub init_fn: Option<String>,
pub extension_file_suffix: String,
pub shared_library: Option<FileData>,
pub object_file_data: Vec<FileData>,
pub is_package: bool,
pub link_libraries: Vec<LibraryDependency>,
pub is_stdlib: bool,
pub builtin_default: bool,
pub required: bool,
pub variant: Option<String>,
pub license: Option<LicensedComponent>,
}
Expand description
Represents a Python extension module.
Fields
name: String
The module name this extension module is providing.
init_fn: Option<String>
Name of the C function initializing this extension module.
extension_file_suffix: String
Filename suffix to use when writing extension module data.
File data for linked extension module.
object_file_data: Vec<FileData>
File data for object files linked together to produce this extension module.
is_package: bool
Whether this extension module is a package.
link_libraries: Vec<LibraryDependency>
Libraries that this extension depends on.
is_stdlib: bool
Whether this extension module is part of the Python standard library.
This is true if the extension is distributed with Python itself.
builtin_default: bool
Whether the extension module is built-in by default.
Some extension modules in Python distributions are always compiled into libpython. This field will be true for those extension modules.
required: bool
Whether the extension must be loaded to initialize Python.
variant: Option<String>
Name of the variant of this extension module.
This may be set if there are multiple versions of an extension module available to choose from.
license: Option<LicensedComponent>
Licenses that apply to this extension.
Implementations
sourceimpl PythonExtensionModule
impl PythonExtensionModule
pub fn description(&self) -> String
pub fn to_memory(&self) -> Result<Self>
sourcepub fn file_name(&self) -> String
pub fn file_name(&self) -> String
The file name (without parent components) this extension module should be realized with.
sourcepub fn resolve_path(&self, prefix: &str) -> PathBuf
pub fn resolve_path(&self, prefix: &str) -> PathBuf
Resolve the filesystem path for this extension module.
sourcepub fn package_parts(&self) -> Vec<String>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A>where
A: Allocator,
pub fn package_parts(&self) -> Vec<String>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A>where
A: Allocator,
A: Allocator,
Returns the part strings constituting the package name.
sourcepub fn requires_libraries(&self) -> bool
pub fn requires_libraries(&self) -> bool
Whether the extension module requires additional libraries.
sourcepub fn is_minimally_required(&self) -> bool
pub fn is_minimally_required(&self) -> bool
Whether the extension module is minimally required for a Python interpreter.
This will be true only for extension modules in the standard library that are builtins part of libpython or are required as part of Python interpreter initialization.
sourcepub fn in_libpython(&self) -> bool
pub fn in_libpython(&self) -> bool
Whether this extension module is already in libpython.
This is true if this is a stdlib extension module and is a core module or no shared library extension module is available.
sourcepub fn top_level_package(&self) -> &str
pub fn top_level_package(&self) -> &str
Obtain the top-level package name this module belongs to.
Trait Implementations
sourceimpl Clone for PythonExtensionModule
impl Clone for PythonExtensionModule
sourcefn clone(&self) -> PythonExtensionModule
fn clone(&self) -> PythonExtensionModule
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more