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
use crate::check_and_update_err;
use common::command::{CliCommand, CliCommandInfo, CliError, ProcessResult};
use common::math::get_sqrt_price_at_tick;
use clap::ArgMatches;
use colored::Colorize;
use solana_clap_utils::keypair::DefaultSigner;
use solana_client::rpc_client::RpcClient;
use solana_remote_wallet::remote_wallet::RemoteWalletManager;
use std::sync::Arc;
use tabled::object::Segment;
use tabled::style::Color;
use tabled::{Alignment, Modify, Panel, Rotate, Style, Table, Tabled};
pub fn parse_tick_price_info<'a>(
matches: &'a ArgMatches,
default_signer: Box<DefaultSigner>,
mut wallet_manager: Box<Option<Arc<RemoteWalletManager>>>,
) -> Result<CliCommandInfo, CliError> {
let tick = matches.value_of("tick");
Ok(CliCommandInfo {
command: Box::new(CliCommand::TickPrice {
tick: tick.unwrap().parse::<i32>().unwrap(),
}),
signers: vec![check_and_update_err!(
default_signer.signer_from_path(matches, wallet_manager.as_mut()),
CliError::RpcRequestError("owner key is invalid".to_string())
)?],
})
}
#[derive(Debug, Tabled)]
pub struct TickPrice {
tick: i32,
price: u128,
}
pub fn process_tick_price_info(_rpc_client: &RpcClient, tick: i32) -> ProcessResult {
let price = get_sqrt_price_at_tick(tick);
let map = TickPrice { tick, price };
let color = Color::try_from(" ".cyan().to_string()).unwrap();
Ok(Table::new(vec![map])
.with(Rotate::Bottom)
.with(Rotate::Right)
.with(Style::modern())
.with(color)
.with(Panel("Tick Price Info", 0))
.with(Modify::new(Segment::all()).with(Alignment::center()))
.to_string())
}