1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
use amethyst_core::bundle::{Result, ResultExt, SystemBundle};
use amethyst_core::specs::prelude::DispatcherBuilder;
use config::DisplayConfig;
use pipe::{PipelineBuild, PolyPipeline};
use system::RenderSystem;
use visibility::VisibilitySortingSystem;
pub struct RenderBundle<'a, B, P>
where
B: PipelineBuild<Pipeline = P>,
P: PolyPipeline,
{
pipe: B,
config: Option<DisplayConfig>,
visibility_sorting: Option<&'a [&'a str]>,
}
impl<'a, B, P> RenderBundle<'a, B, P>
where
B: PipelineBuild<Pipeline = P>,
P: PolyPipeline,
{
pub fn new(pipe: B, config: Option<DisplayConfig>) -> Self {
RenderBundle {
pipe,
config,
visibility_sorting: None,
}
}
pub fn with_visibility_sorting(mut self, dep: &'a [&'a str]) -> Self {
self.visibility_sorting = Some(dep);
self
}
}
impl<'a, 'b, 'c, B: PipelineBuild<Pipeline = P>, P: 'b + PolyPipeline> SystemBundle<'a, 'b>
for RenderBundle<'c, B, P>
{
fn build(self, builder: &mut DispatcherBuilder<'a, 'b>) -> Result<()> {
if let Some(dep) = self.visibility_sorting {
builder.add(
VisibilitySortingSystem::new(),
"visibility_sorting_system",
dep,
);
};
builder
.add_thread_local(RenderSystem::build(self.pipe, self.config).chain_err(|| "Renderer error!")?);
Ok(())
}
}