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
use futures::{future, prelude::*};
use std::sync::Arc;
pub trait PackageApp: PackageRepositoryComponent {
fn new_package<PN>(
&'static self,
package_name: PN,
) -> Box<dyn Future<Item = Arc<Package>, Error = Error>>
where
PN: Into<PackageName>,
{
Box::new(
future::ok(Arc::new(Package::new(package_name)))
.and_then(move |p| self.package_repository().push(p)),
)
}
fn add_command_to_package_of_name<PN, CID>(
&'static self,
package_name: PN,
command_id: CID,
) -> Box<dyn Future<Item = Arc<Package>, Error = Error>>
where
PN: Into<PackageName>,
CID: Into<CommandID>,
{
Box::new(
self.package_repository()
.add_command_to_package_of_name(package_name, command_id),
)
}
}
pub struct Package {
name: PackageName,
}
impl Package {
fn new<PN>(package_name: PN) -> Self
where
PN: Into<PackageName>,
{
Self {
name: package_name.into(),
}
}
}
pub struct Error {}
mod command_id;
mod package_name;
mod package_repository;
pub(self) use self::command_id::*;
pub(self) use self::package_name::*;
pub(self) use self::package_repository::*;