shred
v0.16.1
Эта библиотека позволяет параллельно распределять системы, которые могут иметь взаимозависимости, общий и эксклюзивный доступ к ресурсам.
extern crate shred ;
use shred :: { DispatcherBuilder , Read , Resource , ResourceId , System , SystemData , World , Write } ;
# [ derive ( Debug , Default ) ]
struct ResA ;
# [ derive ( Debug , Default ) ]
struct ResB ;
# [ derive ( SystemData ) ] // Provided with `shred-derive` feature
struct Data < ' a > {
a : Read < ' a , ResA > ,
b : Write < ' a , ResB > ,
}
struct EmptySystem ;
impl < ' a > System < ' a > for EmptySystem {
type SystemData = Data < ' a > ;
fn run ( & mut self , bundle : Data < ' a > ) {
println ! ( "{:?}" , &*bundle.a ) ;
println ! ( "{:?}" , &*bundle.b ) ;
}
}
fn main ( ) {
let mut world = World :: empty ( ) ;
let mut dispatcher = DispatcherBuilder :: new ( )
. with ( EmptySystem , "empty" , & [ ] )
. build ( ) ;
world . insert ( ResA ) ;
world . insert ( ResB ) ;
dispatcher . dispatch ( & mut world ) ;
}
Более крупный (и полезный) пример см. в тесте.
1.56.1 stable
Вклад очень приветствуется! Если вам нужна другая функция, просто создайте проблему. Вы также можете помочь, если хотите; просто выберите вопрос «Требуется помощь». Если вам нужна помощь, не стесняйтесь спрашивать!
Предполагается, что все материалы имеют двойную лицензию MIT/Apache-2.
shred
распространяется на условиях лицензии MIT и лицензии Apache (версия 2.0).
См. LICENSE-APACHE и LICENSE-MIT.