rippled
Loading...
Searching...
No Matches
xrpld/nodestore/Scheduler.h
1//------------------------------------------------------------------------------
2/*
3 This file is part of rippled: https://github.com/ripple/rippled
4 Copyright (c) 2012, 2013 Ripple Labs Inc.
5
6 Permission to use, copy, modify, and/or distribute this software for any
7 purpose with or without fee is hereby granted, provided that the above
8 copyright notice and this permission notice appear in all copies.
9
10 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17*/
18//==============================================================================
19
20#ifndef RIPPLE_NODESTORE_SCHEDULER_H_INCLUDED
21#define RIPPLE_NODESTORE_SCHEDULER_H_INCLUDED
22
23#include <xrpld/nodestore/Task.h>
24
25#include <chrono>
26
27namespace ripple {
28namespace NodeStore {
29
30enum class FetchType { synchronous, async };
31
34{
35 explicit FetchReport(FetchType fetchType_) : fetchType(fetchType_)
36 {
37 }
38
41 bool wasFound = false;
42};
43
52
62{
63public:
64 virtual ~Scheduler() = default;
65
71 virtual void
72 scheduleTask(Task& task) = 0;
73
77 virtual void
78 onFetch(FetchReport const& report) = 0;
79
83 virtual void
84 onBatchWrite(BatchWriteReport const& report) = 0;
85};
86
87} // namespace NodeStore
88} // namespace ripple
89
90#endif
Scheduling for asynchronous backend activity.
virtual void onBatchWrite(BatchWriteReport const &report)=0
Reports the completion of a batch write Allows the scheduler to monitor the node store's performance.
virtual ~Scheduler()=default
virtual void onFetch(FetchReport const &report)=0
Reports completion of a fetch Allows the scheduler to monitor the node store's performance.
virtual void scheduleTask(Task &task)=0
Schedules a task.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition algorithm.h:25
Contains information about a batch write operation.
Contains information about a fetch operation.
Derived classes perform scheduled tasks.
Definition Task.h:28