Ran cargo fmt

This commit is contained in:
G2-Games 2024-01-29 19:44:33 -06:00
parent 1d188c335d
commit 33feb301e8
6 changed files with 345 additions and 318 deletions

View file

@ -4,7 +4,7 @@ use std::error::Error;
use std::time::Duration; use std::time::Duration;
// USB stuff // USB stuff
use nusb::transfer::{Control, ControlType, Recipient, RequestBuffer, ControlIn, ControlOut}; use nusb::transfer::{Control, ControlIn, ControlOut, ControlType, Recipient, RequestBuffer};
use nusb::{Device, DeviceInfo, Interface}; use nusb::{Device, DeviceInfo, Interface};
const DEFAULT_TIMEOUT: Duration = Duration::new(10000, 0); const DEFAULT_TIMEOUT: Duration = Duration::new(10000, 0);
@ -146,16 +146,19 @@ impl NetMD {
/// of the previous command, or the status /// of the previous command, or the status
pub async fn poll(&mut self) -> Result<(u16, [u8; 4]), Box<dyn Error>> { pub async fn poll(&mut self) -> Result<(u16, [u8; 4]), Box<dyn Error>> {
// Create an array to store the result of the poll // Create an array to store the result of the poll
let poll_result = match self.usb_interface.control_in( let poll_result = match self
ControlIn { .usb_interface
.control_in(ControlIn {
control_type: ControlType::Vendor, control_type: ControlType::Vendor,
recipient: Recipient::Interface, recipient: Recipient::Interface,
request: 0x01, request: 0x01,
value: 0, value: 0,
index: 0, index: 0,
length: 4, length: 4,
} })
).await.into_result() { .await
.into_result()
{
Ok(size) => size, Ok(size) => size,
Err(error) => return Err(error.into()), Err(error) => return Err(error.into()),
}; };
@ -198,22 +201,28 @@ impl NetMD {
true => 0xff, true => 0xff,
}; };
match self.usb_interface.control_out( match self
ControlOut { .usb_interface
.control_out(ControlOut {
control_type: ControlType::Vendor, control_type: ControlType::Vendor,
recipient: Recipient::Interface, recipient: Recipient::Interface,
request, request,
value: 0, value: 0,
index: 0, index: 0,
data: &command, data: &command,
} })
).await.into_result() { .await
.into_result()
{
Ok(_) => Ok(()), Ok(_) => Ok(()),
Err(error) => Err(error.into()), Err(error) => Err(error.into()),
} }
} }
pub async fn read_reply(&mut self, override_length: Option<i32>) -> Result<Vec<u8>, Box<dyn Error>> { pub async fn read_reply(
&mut self,
override_length: Option<i32>,
) -> Result<Vec<u8>, Box<dyn Error>> {
self._read_reply(false, override_length).await self._read_reply(false, override_length).await
} }
@ -253,16 +262,18 @@ impl NetMD {
}; };
// Create a buffer to fill with the result // Create a buffer to fill with the result
let reply = self.usb_interface.control_in( let reply = self
ControlIn { .usb_interface
.control_in(ControlIn {
control_type: ControlType::Vendor, control_type: ControlType::Vendor,
recipient: Recipient::Interface, recipient: Recipient::Interface,
request, request,
value: 0, value: 0,
index: 0, index: 0,
length, length,
} })
).await.into_result()?; .await
.into_result()?;
Ok(reply) Ok(reply)
} }
@ -292,7 +303,10 @@ impl NetMD {
done -= to_read; done -= to_read;
let buffer = RequestBuffer::new(to_read); let buffer = RequestBuffer::new(to_read);
let res = match self.usb_interface.bulk_in(BULK_READ_ENDPOINT, buffer).await let res = match self
.usb_interface
.bulk_in(BULK_READ_ENDPOINT, buffer)
.await
.into_result() .into_result()
{ {
Ok(result) => result, Ok(result) => result,
@ -306,10 +320,11 @@ impl NetMD {
} }
pub async fn write_bulk(&mut self, data: Vec<u8>) -> Result<usize, Box<dyn Error>> { pub async fn write_bulk(&mut self, data: Vec<u8>) -> Result<usize, Box<dyn Error>> {
Ok( Ok(self
self.usb_interface.bulk_out(BULK_WRITE_ENDPOINT, data).await .usb_interface
.into_result()? .bulk_out(BULK_WRITE_ENDPOINT, data)
.actual_length(), .await
) .into_result()?
.actual_length())
} }
} }

View file

@ -346,7 +346,11 @@ impl NetMDInterface {
Ok(result) Ok(result)
} }
async fn send_command(&mut self, query: &mut Vec<u8>, test: bool) -> Result<(), Box<dyn Error>> { async fn send_command(
&mut self,
query: &mut Vec<u8>,
test: bool,
) -> Result<(), Box<dyn Error>> {
let status_byte = match test { let status_byte = match test {
true => Status::GeneralInquiry, true => Status::GeneralInquiry,
false => Status::Control, false => Status::Control,
@ -966,7 +970,11 @@ impl NetMDInterface {
} }
// Sets the title of the disc // Sets the title of the disc
pub async fn set_disc_title(&mut self, title: String, wchar: bool) -> Result<(), Box<dyn Error>> { pub async fn set_disc_title(
&mut self,
title: String,
wchar: bool,
) -> Result<(), Box<dyn Error>> {
let current_title = self.raw_disc_title(wchar).await?; let current_title = self.raw_disc_title(wchar).await?;
if current_title == title { if current_title == title {
return Err("Title is already the same".into()); return Err("Title is already the same".into());
@ -1099,7 +1107,12 @@ impl NetMDInterface {
Ok(()) Ok(())
} }
async fn raw_track_info(&mut self, track: u16, p1: i32, p2: i32) -> Result<Vec<u8>, Box<dyn Error>> { async fn raw_track_info(
&mut self,
track: u16,
p1: i32,
p2: i32,
) -> Result<Vec<u8>, Box<dyn Error>> {
self.change_descriptor_state(&Descriptor::AudioContentsTD, &DescriptorAction::OpenRead); self.change_descriptor_state(&Descriptor::AudioContentsTD, &DescriptorAction::OpenRead);
let mut query = format_query( let mut query = format_query(
@ -1167,7 +1180,10 @@ impl NetMDInterface {
} }
/// Gets the length of a track as a `std::time::Duration` /// Gets the length of a track as a `std::time::Duration`
pub async fn track_length(&mut self, track: u16) -> Result<std::time::Duration, Box<dyn Error>> { pub async fn track_length(
&mut self,
track: u16,
) -> Result<std::time::Duration, Box<dyn Error>> {
Ok(self.track_lengths([track].into()).await?[0]) Ok(self.track_lengths([track].into()).await?[0])
} }
@ -1329,7 +1345,7 @@ impl NetMDInterface {
* the root key. * the root key.
* *
* The leaf ID is a 8-byte constant * The leaf ID is a 8-byte constant
**/ **/
pub async fn leaf_id(&mut self) -> Result<Vec<u8>, Box<dyn Error>> { pub async fn leaf_id(&mut self) -> Result<Vec<u8>, Box<dyn Error>> {
let mut query = format_query("1800 080046 f0030103 11 ff".to_string(), vec![])?; let mut query = format_query("1800 080046 f0030103 11 ff".to_string(), vec![])?;
@ -1381,7 +1397,10 @@ impl NetMDInterface {
Ok(res[0].to_vec().unwrap()) Ok(res[0].to_vec().unwrap())
} }
pub async fn session_key_exchange(&mut self, hostnonce: Vec<u8>) -> Result<Vec<u8>, Box<dyn Error>> { pub async fn session_key_exchange(
&mut self,
hostnonce: Vec<u8>,
) -> Result<Vec<u8>, Box<dyn Error>> {
if hostnonce.len() != 8 { if hostnonce.len() != 8 {
return Err("Supplied host nonce length wrong".into()); return Err("Supplied host nonce length wrong".into());
} }

View file

@ -193,7 +193,6 @@ lazy_static! {
("".to_string(), "".to_string()), ("".to_string(), "".to_string()),
("".to_string(), "".to_string()) ("".to_string(), "".to_string())
]); ]);
pub static ref MAPPINGS_RU: HashMap<String, String> = HashMap::from([ pub static ref MAPPINGS_RU: HashMap<String, String> = HashMap::from([
("а".to_string(), "a".to_string()), ("а".to_string(), "a".to_string()),
("б".to_string(), "b".to_string()), ("б".to_string(), "b".to_string()),
@ -262,7 +261,6 @@ lazy_static! {
("Ю".to_string(), "Iu".to_string()), ("Ю".to_string(), "Iu".to_string()),
("Я".to_string(), "Ia".to_string()) ("Я".to_string(), "Ia".to_string())
]); ]);
pub static ref MAPPINGS_DE: HashMap<String, String> = HashMap::from([ pub static ref MAPPINGS_DE: HashMap<String, String> = HashMap::from([
("Ä".to_string(), "Ae".to_string()), ("Ä".to_string(), "Ae".to_string()),
("ä".to_string(), "ae".to_string()), ("ä".to_string(), "ae".to_string()),
@ -272,287 +270,285 @@ lazy_static! {
("ü".to_string(), "ue".to_string()), ("ü".to_string(), "ue".to_string()),
("ß".to_string(), "ss".to_string()) ("ß".to_string(), "ss".to_string())
]); ]);
pub static ref MAPPINGS_HW: HashMap<String, String> = HashMap::from([ pub static ref MAPPINGS_HW: HashMap<String, String> = HashMap::from([
("".to_string(),"-".to_string()), ("".to_string(), "-".to_string()),
("".to_string(),"-".to_string()), ("".to_string(), "-".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ガ".to_string()), ("".to_string(), "ガ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ギ".to_string()), ("".to_string(), "ギ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"グ".to_string()), ("".to_string(), "グ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ゲ".to_string()), ("".to_string(), "ゲ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ゴ".to_string()), ("".to_string(), "ゴ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ザ".to_string()), ("".to_string(), "ザ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ジ".to_string()), ("".to_string(), "ジ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ズ".to_string()), ("".to_string(), "ズ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ゼ".to_string()), ("".to_string(), "ゼ".to_string()),
("".to_string(),"ソ".to_string()), ("".to_string(), "ソ".to_string()),
("".to_string(),"ゾ".to_string()), ("".to_string(), "ゾ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ダ".to_string()), ("".to_string(), "ダ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ヂ".to_string()), ("".to_string(), "ヂ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ヅ".to_string()), ("".to_string(), "ヅ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"デ".to_string()), ("".to_string(), "デ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ド".to_string()), ("".to_string(), "ド".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"バ".to_string()), ("".to_string(), "バ".to_string()),
("".to_string(),"パ".to_string()), ("".to_string(), "パ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ビ".to_string()), ("".to_string(), "ビ".to_string()),
("".to_string(),"ピ".to_string()), ("".to_string(), "ピ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ブ".to_string()), ("".to_string(), "ブ".to_string()),
("".to_string(),"プ".to_string()), ("".to_string(), "プ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ベ".to_string()), ("".to_string(), "ベ".to_string()),
("".to_string(),"ペ".to_string()), ("".to_string(), "ペ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ボ".to_string()), ("".to_string(), "ボ".to_string()),
("".to_string(),"ポ".to_string()), ("".to_string(), "ポ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"-".to_string()), ("".to_string(), "-".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ヴ".to_string()), ("".to_string(), "ヴ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"!".to_string()), ("".to_string(), "!".to_string()),
("".to_string(),"\"".to_string()), ("".to_string(), "\"".to_string()),
("".to_string(),"#".to_string()), ("".to_string(), "#".to_string()),
("".to_string(),"$".to_string()), ("".to_string(), "$".to_string()),
("".to_string(),"%".to_string()), ("".to_string(), "%".to_string()),
("".to_string(),"&".to_string()), ("".to_string(), "&".to_string()),
("".to_string(),"'".to_string()), ("".to_string(), "'".to_string()),
("".to_string(),"(".to_string()), ("".to_string(), "(".to_string()),
("".to_string(),")".to_string()), ("".to_string(), ")".to_string()),
("".to_string(),"*".to_string()), ("".to_string(), "*".to_string()),
("".to_string(),"+".to_string()), ("".to_string(), "+".to_string()),
("".to_string(),",".to_string()), ("".to_string(), ",".to_string()),
("".to_string(),".".to_string()), ("".to_string(), ".".to_string()),
("".to_string(),"/".to_string()), ("".to_string(), "/".to_string()),
("".to_string(),":".to_string()), ("".to_string(), ":".to_string()),
("".to_string(),";".to_string()), ("".to_string(), ";".to_string()),
("".to_string(),"<".to_string()), ("".to_string(), "<".to_string()),
("".to_string(),"=".to_string()), ("".to_string(), "=".to_string()),
("".to_string(),">".to_string()), ("".to_string(), ">".to_string()),
("".to_string(),"?".to_string()), ("".to_string(), "?".to_string()),
("".to_string(),"@".to_string()), ("".to_string(), "@".to_string()),
("".to_string(),"A".to_string()), ("".to_string(), "A".to_string()),
("".to_string(),"B".to_string()), ("".to_string(), "B".to_string()),
("".to_string(),"C".to_string()), ("".to_string(), "C".to_string()),
("".to_string(),"D".to_string()), ("".to_string(), "D".to_string()),
("".to_string(),"E".to_string()), ("".to_string(), "E".to_string()),
("".to_string(),"F".to_string()), ("".to_string(), "F".to_string()),
("".to_string(),"G".to_string()), ("".to_string(), "G".to_string()),
("".to_string(),"H".to_string()), ("".to_string(), "H".to_string()),
("".to_string(),"I".to_string()), ("".to_string(), "I".to_string()),
("".to_string(),"J".to_string()), ("".to_string(), "J".to_string()),
("".to_string(),"K".to_string()), ("".to_string(), "K".to_string()),
("".to_string(),"L".to_string()), ("".to_string(), "L".to_string()),
("".to_string(),"M".to_string()), ("".to_string(), "M".to_string()),
("".to_string(),"N".to_string()), ("".to_string(), "N".to_string()),
("".to_string(),"O".to_string()), ("".to_string(), "O".to_string()),
("".to_string(),"P".to_string()), ("".to_string(), "P".to_string()),
("".to_string(),"Q".to_string()), ("".to_string(), "Q".to_string()),
("".to_string(),"R".to_string()), ("".to_string(), "R".to_string()),
("".to_string(),"S".to_string()), ("".to_string(), "S".to_string()),
("".to_string(),"T".to_string()), ("".to_string(), "T".to_string()),
("".to_string(),"U".to_string()), ("".to_string(), "U".to_string()),
("".to_string(),"V".to_string()), ("".to_string(), "V".to_string()),
("".to_string(),"W".to_string()), ("".to_string(), "W".to_string()),
("".to_string(),"X".to_string()), ("".to_string(), "X".to_string()),
("".to_string(),"Y".to_string()), ("".to_string(), "Y".to_string()),
("".to_string(),"Z".to_string()), ("".to_string(), "Z".to_string()),
("".to_string(),"[".to_string()), ("".to_string(), "[".to_string()),
("".to_string(),"\\".to_string()), ("".to_string(), "\\".to_string()),
("".to_string(),"]".to_string()), ("".to_string(), "]".to_string()),
("".to_string(),"^".to_string()), ("".to_string(), "^".to_string()),
("_".to_string(),"_".to_string()), ("_".to_string(), "_".to_string()),
("".to_string(),"`".to_string()), ("".to_string(), "`".to_string()),
("".to_string(),"a".to_string()), ("".to_string(), "a".to_string()),
("".to_string(),"b".to_string()), ("".to_string(), "b".to_string()),
("".to_string(),"c".to_string()), ("".to_string(), "c".to_string()),
("".to_string(),"d".to_string()), ("".to_string(), "d".to_string()),
("".to_string(),"e".to_string()), ("".to_string(), "e".to_string()),
("".to_string(),"f".to_string()), ("".to_string(), "f".to_string()),
("".to_string(),"g".to_string()), ("".to_string(), "g".to_string()),
("".to_string(),"h".to_string()), ("".to_string(), "h".to_string()),
("".to_string(),"i".to_string()), ("".to_string(), "i".to_string()),
("".to_string(),"j".to_string()), ("".to_string(), "j".to_string()),
("".to_string(),"k".to_string()), ("".to_string(), "k".to_string()),
("".to_string(),"l".to_string()), ("".to_string(), "l".to_string()),
("".to_string(),"m".to_string()), ("".to_string(), "m".to_string()),
("".to_string(),"n".to_string()), ("".to_string(), "n".to_string()),
("".to_string(),"o".to_string()), ("".to_string(), "o".to_string()),
("".to_string(),"p".to_string()), ("".to_string(), "p".to_string()),
("".to_string(),"q".to_string()), ("".to_string(), "q".to_string()),
("".to_string(),"r".to_string()), ("".to_string(), "r".to_string()),
("".to_string(),"s".to_string()), ("".to_string(), "s".to_string()),
("".to_string(),"t".to_string()), ("".to_string(), "t".to_string()),
("".to_string(),"u".to_string()), ("".to_string(), "u".to_string()),
("".to_string(),"v".to_string()), ("".to_string(), "v".to_string()),
("".to_string(),"w".to_string()), ("".to_string(), "w".to_string()),
("".to_string(),"x".to_string()), ("".to_string(), "x".to_string()),
("".to_string(),"y".to_string()), ("".to_string(), "y".to_string()),
("".to_string(),"z".to_string()), ("".to_string(), "z".to_string()),
("".to_string(),"{".to_string()), ("".to_string(), "{".to_string()),
("".to_string(),"|".to_string()), ("".to_string(), "|".to_string()),
("".to_string(),"}".to_string()), ("".to_string(), "}".to_string()),
("".to_string(),"~".to_string()), ("".to_string(), "~".to_string()),
(" ".to_string()," ".to_string()), (" ".to_string(), " ".to_string()),
("".to_string(),"0".to_string()), ("".to_string(), "0".to_string()),
("".to_string(),"1".to_string()), ("".to_string(), "1".to_string()),
("".to_string(),"2".to_string()), ("".to_string(), "2".to_string()),
("".to_string(),"3".to_string()), ("".to_string(), "3".to_string()),
("".to_string(),"4".to_string()), ("".to_string(), "4".to_string()),
("".to_string(),"5".to_string()), ("".to_string(), "5".to_string()),
("".to_string(),"6".to_string()), ("".to_string(), "6".to_string()),
("".to_string(),"7".to_string()), ("".to_string(), "7".to_string()),
("".to_string(),"8".to_string()), ("".to_string(), "8".to_string()),
("".to_string(),"9".to_string()), ("".to_string(), "9".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ガ".to_string()), ("".to_string(), "ガ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ギ".to_string()), ("".to_string(), "ギ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"グ".to_string()), ("".to_string(), "グ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ゲ".to_string()), ("".to_string(), "ゲ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ゴ".to_string()), ("".to_string(), "ゴ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ザ".to_string()), ("".to_string(), "ザ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ジ".to_string()), ("".to_string(), "ジ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ズ".to_string()), ("".to_string(), "ズ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ゼ".to_string()), ("".to_string(), "ゼ".to_string()),
("".to_string(),"ソ".to_string()), ("".to_string(), "ソ".to_string()),
("".to_string(),"ゾ".to_string()), ("".to_string(), "ゾ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ダ".to_string()), ("".to_string(), "ダ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ヂ".to_string()), ("".to_string(), "ヂ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ヅ".to_string()), ("".to_string(), "ヅ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"デ".to_string()), ("".to_string(), "デ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ド".to_string()), ("".to_string(), "ド".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"バ".to_string()), ("".to_string(), "バ".to_string()),
("".to_string(),"パ".to_string()), ("".to_string(), "パ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ビ".to_string()), ("".to_string(), "ビ".to_string()),
("".to_string(),"ピ".to_string()), ("".to_string(), "ピ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ブ".to_string()), ("".to_string(), "ブ".to_string()),
("".to_string(),"プ".to_string()), ("".to_string(), "プ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ベ".to_string()), ("".to_string(), "ベ".to_string()),
("".to_string(),"ペ".to_string()), ("".to_string(), "ペ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ボ".to_string()), ("".to_string(), "ボ".to_string()),
("".to_string(),"ポ".to_string()), ("".to_string(), "ポ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"ヴ".to_string()), ("".to_string(), "ヴ".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
("".to_string(),"".to_string()), ("".to_string(), "".to_string()),
]); ]);
pub static ref ALLOWED_HW_KANA: Vec<String> = MAPPINGS_HW.values().cloned().collect(); pub static ref ALLOWED_HW_KANA: Vec<String> = MAPPINGS_HW.values().cloned().collect();
} }

View file

@ -6,6 +6,6 @@
mod base; mod base;
pub mod interface; pub mod interface;
mod mappings;
mod query_utils; mod query_utils;
mod utils; mod utils;
mod mappings;

View file

@ -3,7 +3,7 @@ use lazy_static::lazy_static;
use std::collections::hash_map::HashMap; use std::collections::hash_map::HashMap;
use std::error::Error; use std::error::Error;
lazy_static!{ lazy_static! {
/// %b, w, d, q - explained above (can have endiannes overriden by '>' and '<' operators, f. ex. %>d %<q) /// %b, w, d, q - explained above (can have endiannes overriden by '>' and '<' operators, f. ex. %>d %<q)
/// %s - Uint8Array preceded by 2 bytes of length /// %s - Uint8Array preceded by 2 bytes of length
/// %x - Uint8Array preceded by 2 bytes of length /// %x - Uint8Array preceded by 2 bytes of length
@ -44,10 +44,7 @@ impl QueryValue {
} }
/// Formats a query using a standard input to send to the player /// Formats a query using a standard input to send to the player
pub fn format_query( pub fn format_query(format: String, args: Vec<QueryValue>) -> Result<Vec<u8>, Box<dyn Error>> {
format: String,
args: Vec<QueryValue>,
) -> Result<Vec<u8>, Box<dyn Error>> {
if DEBUG { if DEBUG {
println!("SENT>>> F: {}", format); println!("SENT>>> F: {}", format);
} }

View file

@ -59,9 +59,7 @@ pub fn half_width_to_full_width_range(range: &str) -> String {
.collect() .collect()
} }
pub fn get_bytes<const S: usize>( pub fn get_bytes<const S: usize>(iterator: &mut IntoIter<u8>) -> Result<[u8; S], Box<dyn Error>> {
iterator: &mut IntoIter<u8>,
) -> Result<[u8; S], Box<dyn Error>> {
let byte_vec: Vec<u8> = iterator.take(S).collect(); let byte_vec: Vec<u8> = iterator.take(S).collect();
let bytes: [u8; S] = byte_vec.try_into().unwrap(); let bytes: [u8; S] = byte_vec.try_into().unwrap();
@ -170,5 +168,7 @@ pub fn agressive_sanitize_title(title: &str) -> String {
pub fn time_to_duration(time: &Vec<u64>) -> std::time::Duration { pub fn time_to_duration(time: &Vec<u64>) -> std::time::Duration {
assert_eq!(time.len(), 4); assert_eq!(time.len(), 4);
std::time::Duration::from_micros((time[0] * 3600000000) + (time[1] * 60000000) + (time[2] * 1000000) + (time[3] * 11600)) std::time::Duration::from_micros(
(time[0] * 3600000000) + (time[1] * 60000000) + (time[2] * 1000000) + (time[3] * 11600),
)
} }