Add CLI option and route to MinerOptions.
This commit is contained in:
parent
78ebc8b975
commit
7c27f9dfed
@ -44,6 +44,8 @@ pub enum PendingSet {
|
|||||||
/// Configures the behaviour of the miner.
|
/// Configures the behaviour of the miner.
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct MinerOptions {
|
pub struct MinerOptions {
|
||||||
|
/// URLs to notify when there is new work.
|
||||||
|
pub new_work_notify: Vec<String>,
|
||||||
/// Force the miner to reseal, even when nobody has asked for work.
|
/// Force the miner to reseal, even when nobody has asked for work.
|
||||||
pub force_sealing: bool,
|
pub force_sealing: bool,
|
||||||
/// Reseal on receipt of new external transactions.
|
/// Reseal on receipt of new external transactions.
|
||||||
@ -61,6 +63,7 @@ pub struct MinerOptions {
|
|||||||
impl Default for MinerOptions {
|
impl Default for MinerOptions {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
MinerOptions {
|
MinerOptions {
|
||||||
|
new_work_notify: vec![],
|
||||||
force_sealing: false,
|
force_sealing: false,
|
||||||
reseal_on_external_tx: true,
|
reseal_on_external_tx: true,
|
||||||
reseal_on_own_tx: true,
|
reseal_on_own_tx: true,
|
||||||
|
@ -162,6 +162,8 @@ Sealing/Mining Options:
|
|||||||
more than 32 characters.
|
more than 32 characters.
|
||||||
--tx-queue-size LIMIT Maximum amount of transactions in the queue (waiting
|
--tx-queue-size LIMIT Maximum amount of transactions in the queue (waiting
|
||||||
to be included in next block) [default: 1024].
|
to be included in next block) [default: 1024].
|
||||||
|
--notify-work URLS URLs to which work package notifications are pushed.
|
||||||
|
URLS should be a comma-delimited list of HTTP URLs.
|
||||||
|
|
||||||
Footprint Options:
|
Footprint Options:
|
||||||
--tracing BOOL Indicates if full transaction tracing should be
|
--tracing BOOL Indicates if full transaction tracing should be
|
||||||
@ -311,6 +313,7 @@ pub struct Args {
|
|||||||
pub flag_gas_cap: String,
|
pub flag_gas_cap: String,
|
||||||
pub flag_extra_data: Option<String>,
|
pub flag_extra_data: Option<String>,
|
||||||
pub flag_tx_queue_size: usize,
|
pub flag_tx_queue_size: usize,
|
||||||
|
pub flag_work_notify: Option<String>,
|
||||||
pub flag_logging: Option<String>,
|
pub flag_logging: Option<String>,
|
||||||
pub flag_version: bool,
|
pub flag_version: bool,
|
||||||
pub flag_from: String,
|
pub flag_from: String,
|
||||||
|
@ -83,6 +83,10 @@ impl Configuration {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn work_notify(&self) -> Vec<String> {
|
||||||
|
self.args.flag_work_notify.as_ref().map_or_else(Vec::new, |s| s.split(',').map(|s| s.to_owned()).collect())
|
||||||
|
}
|
||||||
|
|
||||||
pub fn miner_options(&self) -> MinerOptions {
|
pub fn miner_options(&self) -> MinerOptions {
|
||||||
let (own, ext) = match self.args.flag_reseal_on_txs.as_str() {
|
let (own, ext) = match self.args.flag_reseal_on_txs.as_str() {
|
||||||
"none" => (false, false),
|
"none" => (false, false),
|
||||||
@ -92,6 +96,7 @@ impl Configuration {
|
|||||||
x => die!("{}: Invalid value for --reseal option. Use --help for more information.", x)
|
x => die!("{}: Invalid value for --reseal option. Use --help for more information.", x)
|
||||||
};
|
};
|
||||||
MinerOptions {
|
MinerOptions {
|
||||||
|
new_work_notify: self.work_notify(),
|
||||||
force_sealing: self.args.flag_force_sealing,
|
force_sealing: self.args.flag_force_sealing,
|
||||||
reseal_on_external_tx: ext,
|
reseal_on_external_tx: ext,
|
||||||
reseal_on_own_tx: own,
|
reseal_on_own_tx: own,
|
||||||
|
Loading…
Reference in New Issue
Block a user