#[repr(transparent)]pub struct Module<'scope>(_, _);
Expand description
Functionality in Julia can be accessed through its module system. You can get a handle to the
three standard modules, Main
, Base
, and Core
and access their submodules through them.
If you include your own Julia code with Julia::include
or AsyncJulia::include
, its
contents are made available relative to Main
.
The most important methods offered are those that let you access submodules, functions, and other global values defined in the module.
Implementations§
source§impl<'scope> Module<'scope>
impl<'scope> Module<'scope>
sourcepub unsafe fn extend<'target, T>(self, _: &T) -> Module<'target>where
T: Target<'target>,
pub unsafe fn extend<'target, T>(self, _: &T) -> Module<'target>where T: Target<'target>,
Extend the lifetime of this module. This is safe as long as the module is never redefined.
sourcepub fn main<T: Target<'scope>>(_: &T) -> Self
pub fn main<T: Target<'scope>>(_: &T) -> Self
Returns a handle to Julia’s Main
-module. If you include your own Julia code with
Julia::include
or AsyncJulia::include
its contents are made available relative to
Main
.
sourcepub fn is_imported<N: ToSymbol>(self, sym: N) -> bool
pub fn is_imported<N: ToSymbol>(self, sym: N) -> bool
Returns true
if self
has imported sym
.
sourcepub fn binding_type<'target, N, T>(
self,
target: T,
var: N
) -> Option<ValueData<'target, 'static, T>>where
N: ToSymbol,
T: Target<'target>,
pub fn binding_type<'target, N, T>( self, target: T, var: N ) -> Option<ValueData<'target, 'static, T>>where N: ToSymbol, T: Target<'target>,
Returns the type of the binding in this module with the name var
,
sourcepub fn submodule<'target, N, T>(
self,
target: T,
name: N
) -> JlrsResult<ModuleData<'target, T>>where
N: ToSymbol,
T: Target<'target>,
pub fn submodule<'target, N, T>( self, target: T, name: N ) -> JlrsResult<ModuleData<'target, T>>where N: ToSymbol, T: Target<'target>,
Returns the submodule named name
relative to this module. You have to visit this level
by level: you can’t access Main.A.B
by calling this function with "A.B"
, but have to
access A
first and then B
.
Returns an error if the submodule doesn’t exist.
sourcepub fn package_root_module<'target, N: ToSymbol, T: Target<'target>>(
target: &T,
name: N
) -> Option<Module<'target>>
pub fn package_root_module<'target, N: ToSymbol, T: Target<'target>>( target: &T, name: N ) -> Option<Module<'target>>
Returns the root module of the package named name
.
All loaded packages can be accessed with this method. If the package doesn’t exist or
hasn’t been loaded yet, None
is returned.
sourcepub unsafe fn set_global<'target, N, T>(
self,
target: T,
name: N,
value: Value<'_, 'static>
) -> T::Exception<'static, ()>where
N: ToSymbol,
T: Target<'target>,
pub unsafe fn set_global<'target, N, T>( self, target: T, name: N, value: Value<'_, 'static> ) -> T::Exception<'static, ()>where N: ToSymbol, T: Target<'target>,
Set a global value in this module. Note that if this global already exists, this can make the old value unreachable. If an excection is thrown, it’s caught, rooted and returned.
Safety: Mutating Julia data is generally unsafe because it can’t be guaranteed mutating this value is allowed.
sourcepub unsafe fn set_global_unchecked<N>(self, name: N, value: Value<'_, 'static>)where
N: ToSymbol,
pub unsafe fn set_global_unchecked<N>(self, name: N, value: Value<'_, 'static>)where N: ToSymbol,
Set a global value in this module. Note that if this global already exists, this can make the old value unreachable.
Safety: Mutating Julia data is generally unsafe because it can’t be guaranteed mutating this value is allowed.
sourcepub fn set_const<'target, N, T>(
self,
target: T,
name: N,
value: Value<'_, 'static>
) -> T::Exception<'static, Value<'scope, 'static>>where
N: ToSymbol,
T: Target<'target>,
pub fn set_const<'target, N, T>( self, target: T, name: N, value: Value<'_, 'static> ) -> T::Exception<'static, Value<'scope, 'static>>where N: ToSymbol, T: Target<'target>,
Set a constant in this module. If Julia throws an exception it’s caught and rooted in the
current frame, if the exception can’t be rooted a JlrsError::AllocError
is returned. If
no exception is thrown an unrooted reference to the constant is returned.
sourcepub unsafe fn set_const_unchecked<N>(
self,
name: N,
value: Value<'_, 'static>
) -> Value<'scope, 'static>where
N: ToSymbol,
pub unsafe fn set_const_unchecked<N>( self, name: N, value: Value<'_, 'static> ) -> Value<'scope, 'static>where N: ToSymbol,
Set a constant in this module. If the constant already exists the process aborts, otherwise an unrooted reference to the constant is returned.
Safety: This method must not throw an error if called from a ccall
ed function.
sourcepub fn global<'target, N, T>(
self,
target: T,
name: N
) -> JlrsResult<ValueData<'target, 'static, T>>where
N: ToSymbol,
T: Target<'target>,
pub fn global<'target, N, T>( self, target: T, name: N ) -> JlrsResult<ValueData<'target, 'static, T>>where N: ToSymbol, T: Target<'target>,
Returns the global named name
in this module.
Returns an error if the global doesn’t exist.
sourcepub fn function<'target, N, T>(
self,
target: T,
name: N
) -> JlrsResult<FunctionData<'target, 'static, T>>where
N: ToSymbol,
T: Target<'target>,
pub fn function<'target, N, T>( self, target: T, name: N ) -> JlrsResult<FunctionData<'target, 'static, T>>where N: ToSymbol, T: Target<'target>,
Returns the function named name
in this module.
Returns an error if the function doesn’t exist or if it’s not a subtype of Function
.
sourcepub unsafe fn require<'target, T, N>(
self,
target: T,
module: N
) -> ValueResult<'target, 'static, T>where
T: Target<'target>,
N: ToSymbol,
pub unsafe fn require<'target, T, N>( self, target: T, module: N ) -> ValueResult<'target, 'static, T>where T: Target<'target>, N: ToSymbol,
Load a module by calling Base.require
and return this module if it has been loaded
successfully. This method can be used to load parts of the standard library like
LinearAlgebra
. This requires one slot on the GC stack. Note that the loaded module is
not made available in the module used to call this method, you can use
Module::set_global
to do so.
Note that when you want to call using Submodule
in the Main
module, you can do so by
evaluating the using-statement with Value::eval_string
.
Safety: This method can execute arbitrary Julia code depending on the module that is loaded.
Trait Implementations§
source§impl<'scope> AccessPlotsModule for Module<'scope>
impl<'scope> AccessPlotsModule for Module<'scope>
source§impl<'scope, 'data> AsTyped<'scope, 'data> for Module<'scope>
impl<'scope, 'data> AsTyped<'scope, 'data> for Module<'scope>
fn as_typed(self) -> JlrsResult<TypedValue<'scope, 'data, Self>>
source§impl<'scope> CCallArg for Module<'scope>
impl<'scope> CCallArg for Module<'scope>
type CCallArgType = Value<'scope, 'static>
type FunctionArgType = Module<'scope>
source§impl ConstructType for Module<'_>
impl ConstructType for Module<'_>
source§fn construct_type<'target, 'current, 'borrow, T>(
target: ExtendedTarget<'target, '_, '_, T>
) -> ValueData<'target, 'static, T>where
T: Target<'target>,
fn construct_type<'target, 'current, 'borrow, T>( target: ExtendedTarget<'target, '_, '_, T> ) -> ValueData<'target, 'static, T>where T: Target<'target>,
source§fn base_type<'target, Tgt>(_target: &Tgt) -> Option<Value<'target, 'static>>where
Tgt: Target<'target>,
fn base_type<'target, Tgt>(_target: &Tgt) -> Option<Value<'target, 'static>>where Tgt: Target<'target>,
source§fn is_compatible<T>(frame: &mut GcFrame<'_>) -> boolwhere
T: ValidField,
fn is_compatible<T>(frame: &mut GcFrame<'_>) -> boolwhere T: ValidField,
true
if T
is a valid field layout for instances of the constructed type.source§impl<'scope> PartialEq<Module<'scope>> for Module<'scope>
impl<'scope> PartialEq<Module<'scope>> for Module<'scope>
source§impl ValidLayout for Module<'_>
impl ValidLayout for Module<'_>
source§fn valid_layout(ty: Value<'_, '_>) -> bool
fn valid_layout(ty: Value<'_, '_>) -> bool
ty
. This
argument is a Value
to account for the fact that a field type can be a Union
,
UnionAll
or Union{}
.impl<'scope> Copy for Module<'scope>
impl<'scope> StructuralPartialEq for Module<'scope>
Auto Trait Implementations§
impl<'scope> RefUnwindSafe for Module<'scope>
impl<'scope> !Send for Module<'scope>
impl<'scope> !Sync for Module<'scope>
impl<'scope> Unpin for Module<'scope>
impl<'scope> UnwindSafe for Module<'scope>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CompatibleCast for Twhere
T: ValidLayout,
impl<T> CompatibleCast for Twhere T: ValidLayout,
type Inner = T
type Output = U
source§fn compatible_cast<U>(&self) -> &<T as CompatibleCast>::Output<U>where
T: Compatible<U>,
fn compatible_cast<U>(&self) -> &<T as CompatibleCast>::Output<U>where T: Compatible<U>,
&Self
to &U
, &[Self]
to &[U]
, and &[Self; N]
to &[U; N]
.source§fn compatible_cast_mut<U>(&mut self) -> &mut <T as CompatibleCast>::Output<U>where
T: Compatible<U>,
fn compatible_cast_mut<U>(&mut self) -> &mut <T as CompatibleCast>::Output<U>where T: Compatible<U>,
&mut Self
to &mut U
, &mut [Self]
to &mut [U]
, and &mut [Self; N]
to
&mut [U; N]
.§impl<T> Conv for T
impl<T> Conv for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where &'a Self: for<'a> IntoIterator,
source§impl<'scope, 'data, W> Managed<'scope, 'data> for Wwhere
W: ManagedPriv<'scope, 'data>,
impl<'scope, 'data, W> Managed<'scope, 'data> for Wwhere W: ManagedPriv<'scope, 'data>,
§type TypeConstructor = <W as ManagedPriv<'scope, 'data>>::TypeConstructorPriv<'target, 'da>
type TypeConstructor = <W as ManagedPriv<'scope, 'data>>::TypeConstructorPriv<'target, 'da>
Self
, but with arbitrary lifetimes. Used to construct the appropriate type in generic
contexts.source§fn root<'target, T>(
self,
target: T
) -> T::Data<'data, Self::TypeConstructor<'target, 'data>>where
T: Target<'target>,
fn root<'target, T>( self, target: T ) -> T::Data<'data, Self::TypeConstructor<'target, 'data>>where T: Target<'target>,
source§fn unrooted_target(self) -> Unrooted<'scope>
fn unrooted_target(self) -> Unrooted<'scope>
Unrooted
.source§fn display_string(self) -> JlrsResult<String>
fn display_string(self) -> JlrsResult<String>
Base.show
.source§fn error_string(self) -> JlrsResult<String>
fn error_string(self) -> JlrsResult<String>
Base.showerror
. This string can contain ANSI color codes if this is enabled by calling
Julia::error_color
or AsyncJulia::error_color
.source§fn display_string_or<S: Into<String>>(self, default: S) -> String
fn display_string_or<S: Into<String>>(self, default: S) -> String
Base.display
, or some default value.§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere
Self: Borrow<B>,
B: 'a + ?Sized,
R: 'a,
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere Self: Borrow<B>, B: 'a + ?Sized, R: 'a,
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R
) -> Rwhere
Self: BorrowMut<B>,
B: 'a + ?Sized,
R: 'a,
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> Rwhere Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere
Self: AsRef<U>,
U: 'a + ?Sized,
R: 'a,
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere Self: AsRef<U>, U: 'a + ?Sized, R: 'a,
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere
Self: AsMut<U>,
U: 'a + ?Sized,
R: 'a,
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere Self: AsMut<U>, U: 'a + ?Sized, R: 'a,
self
, then passes self.as_mut()
into the pipe
function.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere
Self: Borrow<B>,
B: ?Sized,
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere
Self: BorrowMut<B>,
B: ?Sized,
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere
Self: AsRef<R>,
R: ?Sized,
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere
Self: AsMut<R>,
R: ?Sized,
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere
Self: Deref<Target = T>,
T: ?Sized,
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere Self: Deref<Target = T>, T: ?Sized,
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere
Self: DerefMut<Target = T> + Deref,
T: ?Sized,
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere Self: DerefMut<Target = T> + Deref, T: ?Sized,
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere
Self: Borrow<B>,
B: ?Sized,
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere
Self: BorrowMut<B>,
B: ?Sized,
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere
Self: AsRef<R>,
R: ?Sized,
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere
Self: AsMut<R>,
R: ?Sized,
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,
.tap_ref_mut()
only in debug builds, and is erased in release
builds.