Struct puffin::fuzzer::libafl_setup::RunClientBuilder
source · struct RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>where
PT: ProtocolTypes + 'static,{Show 13 fields
config: FuzzerConfig,
harness_fn: &'harness mut H,
existing_state: Option<StdState<Trace<PT>, C, R, SC>>,
rand: Option<R>,
objective_corpus: Option<SC>,
corpus: Option<C>,
scheduler: Option<CS>,
event_manager: EM,
observers: Option<OT>,
feedback: Option<F>,
objective: Option<OF>,
initial_inputs: Option<Vec<(Trace<PT>, &'static str)>>,
phantom_data: PhantomData<PT>,
}
Fields§
§config: FuzzerConfig
§harness_fn: &'harness mut H
§existing_state: Option<StdState<Trace<PT>, C, R, SC>>
§rand: Option<R>
§objective_corpus: Option<SC>
§corpus: Option<C>
§scheduler: Option<CS>
§event_manager: EM
§observers: Option<OT>
§feedback: Option<F>
§objective: Option<OF>
§initial_inputs: Option<Vec<(Trace<PT>, &'static str)>>
§phantom_data: PhantomData<PT>
Implementations§
source§impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>where
StdState<Trace<PT>, C, R, SC>: UsesInput<Input = Trace<PT>>,
C: Corpus + UsesInput<Input = Trace<PT>>,
R: Rand,
SC: Corpus + UsesInput<Input = Trace<PT>>,
H: FnMut(&Trace<PT>) -> ExitKind,
CS: Scheduler + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
F: Feedback<StdState<Trace<PT>, C, R, SC>>,
OF: Feedback<StdState<Trace<PT>, C, R, SC>>,
OT: ObserversTuple<StdState<Trace<PT>, C, R, SC>> + Serialize + DeserializeOwned,
EM: EventFirer + EventRestarter + EventManager<TimeoutExecutor<InProcessExecutor<'harness, H, OT, StdState<Trace<PT>, C, R, SC>>>, StdFuzzer<CS, F, OF, OT>> + ProgressReporter + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
<EM as UsesState>::State: HasClientPerfMonitor + HasMetadata + HasExecutions,
PT: ProtocolTypes + 'static,
impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>where
StdState<Trace<PT>, C, R, SC>: UsesInput<Input = Trace<PT>>,
C: Corpus + UsesInput<Input = Trace<PT>>,
R: Rand,
SC: Corpus + UsesInput<Input = Trace<PT>>,
H: FnMut(&Trace<PT>) -> ExitKind,
CS: Scheduler + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
F: Feedback<StdState<Trace<PT>, C, R, SC>>,
OF: Feedback<StdState<Trace<PT>, C, R, SC>>,
OT: ObserversTuple<StdState<Trace<PT>, C, R, SC>> + Serialize + DeserializeOwned,
EM: EventFirer + EventRestarter + EventManager<TimeoutExecutor<InProcessExecutor<'harness, H, OT, StdState<Trace<PT>, C, R, SC>>>, StdFuzzer<CS, F, OF, OT>> + ProgressReporter + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
<EM as UsesState>::State: HasClientPerfMonitor + HasMetadata + HasExecutions,
PT: ProtocolTypes + 'static,
fn new( config: FuzzerConfig, harness_fn: &'harness mut H, existing_state: Option<StdState<Trace<PT>, C, R, SC>>, event_manager: EM, ) -> Self
fn with_rand(self, rand: R) -> Self
fn with_corpus(self, corpus: C) -> Self
fn with_objective_corpus(self, objective_corpus: SC) -> Self
fn with_scheduler(self, scheduler: CS) -> Self
fn with_feedback(self, feedback: F) -> Self
fn with_objective(self, objective: OF) -> Self
fn with_observers(self, observers: OT) -> Self
fn with_initial_inputs( self, initial_inputs: Vec<(Trace<PT>, &'static str)>, ) -> Self
fn run_client<PB>(
self,
put_registry: &'harness PutRegistry<PB>,
) -> Result<(), Error>where
PB: ProtocolBehavior<ProtocolTypes = PT> + 'static,
source§impl<'harness, 'a, H, SC, C, R, EM, OF, CS, PT> RunClientBuilder<'harness, H, C, R, SC, EM, CombinedFeedback<MinimizingFeedback<StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>, PT>, CombinedFeedback<MapFeedback<DifferentIsNovel, HitcountsMapObserver<StdMapObserver<'_, u8, false>>, MaxReducer, StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>, u8>, TimeFeedback, LogicEagerOr, StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>>, LogicEagerOr, StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>>, OF, (HitcountsMapObserver<StdMapObserver<'a, u8, false>>, (TimeObserver, ())), CS, PT>where
StdState<Trace<PT>, C, R, SC>: UsesInput<Input = Trace<PT>>,
C: Corpus + UsesInput<Input = Trace<PT>> + Debug,
R: Rand,
SC: Corpus + UsesInput<Input = Trace<PT>> + Debug,
H: FnMut(&Trace<PT>) -> ExitKind,
OF: Feedback<StdState<Trace<PT>, C, R, SC>>,
CS: Scheduler + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
EM: EventFirer + EventRestarter + EventManager<TimeoutExecutor<InProcessExecutor<'harness, H, (HitcountsMapObserver<StdMapObserver<'a, u8, false>>, (TimeObserver, ())), StdState<Trace<PT>, C, R, SC>>>, StdFuzzer<IndexesLenTimeMinimizerScheduler<QueueScheduler<StdState<Trace<PT>, C, R, SC>>>, CombinedFeedback<MapFeedback<DifferentIsNovel, HitcountsMapObserver<StdMapObserver<'a, u8, false>>, MaxReducer, StdState<Trace<PT>, C, R, SC>, u8>, TimeFeedback, LogicEagerOr, StdState<Trace<PT>, C, R, SC>>, OF, (HitcountsMapObserver<StdMapObserver<'a, u8, false>>, (TimeObserver, ()))>> + ProgressReporter + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
<EM as UsesState>::State: HasClientPerfMonitor + HasMetadata + HasExecutions,
PT: ProtocolTypes + 'static,
impl<'harness, 'a, H, SC, C, R, EM, OF, CS, PT> RunClientBuilder<'harness, H, C, R, SC, EM, CombinedFeedback<MinimizingFeedback<StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>, PT>, CombinedFeedback<MapFeedback<DifferentIsNovel, HitcountsMapObserver<StdMapObserver<'_, u8, false>>, MaxReducer, StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>, u8>, TimeFeedback, LogicEagerOr, StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>>, LogicEagerOr, StdState<Trace<PT>, CachedOnDiskCorpus<Trace<PT>>, RomuDuoJrRand, CachedOnDiskCorpus<Trace<PT>>>>, OF, (HitcountsMapObserver<StdMapObserver<'a, u8, false>>, (TimeObserver, ())), CS, PT>where
StdState<Trace<PT>, C, R, SC>: UsesInput<Input = Trace<PT>>,
C: Corpus + UsesInput<Input = Trace<PT>> + Debug,
R: Rand,
SC: Corpus + UsesInput<Input = Trace<PT>> + Debug,
H: FnMut(&Trace<PT>) -> ExitKind,
OF: Feedback<StdState<Trace<PT>, C, R, SC>>,
CS: Scheduler + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
EM: EventFirer + EventRestarter + EventManager<TimeoutExecutor<InProcessExecutor<'harness, H, (HitcountsMapObserver<StdMapObserver<'a, u8, false>>, (TimeObserver, ())), StdState<Trace<PT>, C, R, SC>>>, StdFuzzer<IndexesLenTimeMinimizerScheduler<QueueScheduler<StdState<Trace<PT>, C, R, SC>>>, CombinedFeedback<MapFeedback<DifferentIsNovel, HitcountsMapObserver<StdMapObserver<'a, u8, false>>, MaxReducer, StdState<Trace<PT>, C, R, SC>, u8>, TimeFeedback, LogicEagerOr, StdState<Trace<PT>, C, R, SC>>, OF, (HitcountsMapObserver<StdMapObserver<'a, u8, false>>, (TimeObserver, ()))>> + ProgressReporter + UsesState<State = StdState<Trace<PT>, C, R, SC>>,
<EM as UsesState>::State: HasClientPerfMonitor + HasMetadata + HasExecutions,
PT: ProtocolTypes + 'static,
fn create_feedback_observers( &self, ) -> (CombinedFeedback<MapFeedback<DifferentIsNovel, HitcountsMapObserver<StdMapObserver<'a, u8, false>>, MaxReducer, StdState<Trace<PT>, C, R, SC>, u8>, TimeFeedback, LogicEagerOr, StdState<Trace<PT>, C, R, SC>>, (HitcountsMapObserver<StdMapObserver<'a, u8, false>>, (TimeObserver, ())))
Auto Trait Implementations§
impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> Freeze for RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>
impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> !RefUnwindSafe for RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>
impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> !Send for RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>
impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> !Sync for RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>
impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> Unpin for RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>
impl<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT> !UnwindSafe for RunClientBuilder<'harness, H, C, R, SC, EM, F, OF, OT, CS, PT>
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
Mutably borrows from an owned value. Read more
§impl<Tail, T> Prepend<T> for Tail
impl<Tail, T> Prepend<T> for Tail
§type PreprendResult = Tail
type PreprendResult = Tail
The Resulting [
TupleList
], of an [Prepend::prepend()
] call,
including the prepended entry.