pub struct Build<'a, S> { /* private fields */ }
Expand description
A builder for a Unit.
See rune::prepare
for more.
Implementations§
Source§impl<'a, S> Build<'a, S>
impl<'a, S> Build<'a, S>
Sourcepub fn with_context(self, context: &'a Context) -> Self
pub fn with_context(self, context: &'a Context) -> Self
Modify the current Build
to use the given Context
while
building.
If unspecified the empty context constructed with Context::new
will
be used. Since this counts as building without a context,
Vm::without_runtime
can be used when running the produced Unit
.
Sourcepub fn with_diagnostics(self, diagnostics: &'a mut Diagnostics) -> Self
pub fn with_diagnostics(self, diagnostics: &'a mut Diagnostics) -> Self
Modify the current Build to use the given Diagnostics collection.
Sourcepub fn with_options(self, options: &'a Options) -> Self
pub fn with_options(self, options: &'a Options) -> Self
Sourcepub fn with_visitor(self, visitor: &'a mut dyn CompileVisitor) -> Result<Self>
pub fn with_visitor(self, visitor: &'a mut dyn CompileVisitor) -> Result<Self>
Modify the current Build to configure the given CompileVisitor.
A compile visitor allows for custom collecting of compile-time metadata. Like if you want to collect every function that is discovered in the project.
Sourcepub fn with_source_loader(self, source_loader: &'a mut dyn SourceLoader) -> Self
pub fn with_source_loader(self, source_loader: &'a mut dyn SourceLoader) -> Self
Modify the current Build to configure the given SourceLoader.
Source loaders are used to determine how sources are loaded externally from the current file (as is neede when a module is imported).
Sourcepub fn build(self) -> Result<Unit<S>, BuildError>where
S: Default + UnitEncoder,
pub fn build(self) -> Result<Unit<S>, BuildError>where
S: Default + UnitEncoder,
Build a Unit
with the current configuration.
See rune::prepare
for more.