102 lines
3 KiB
Rust
102 lines
3 KiB
Rust
pub mod models;
|
|
|
|
/// Panic if an error happened
|
|
pub fn check_errors(html: &String, loc: &str) {
|
|
match html {
|
|
t if t.contains(&err_code(429)) => panic!(
|
|
"URL: {} • HTTP 429: Slow down - Rate limited (too many access attempts detected)",
|
|
loc
|
|
),
|
|
_ => (),
|
|
}
|
|
}
|
|
|
|
/// Create String error code
|
|
fn err_code(code: i32) -> String {
|
|
format!("HTTP Code : {}", code)
|
|
}
|
|
|
|
/// Print a line for the table
|
|
pub fn line_table(
|
|
cell_length_hours: usize,
|
|
cell_length: usize,
|
|
number_cell: usize,
|
|
pos: models::Position,
|
|
skip_with: std::collections::HashMap<usize, &str>,
|
|
) {
|
|
// Left side
|
|
let ls = match pos {
|
|
models::Position::Top => models::TabChar::Jtl.val(),
|
|
models::Position::Middle => models::TabChar::Jl.val(),
|
|
models::Position::Bottom => models::TabChar::Jbl.val(),
|
|
};
|
|
|
|
// Middle
|
|
let ms = match pos {
|
|
models::Position::Top => models::TabChar::Jtb.val(),
|
|
models::Position::Middle => models::TabChar::Jm.val(),
|
|
models::Position::Bottom => models::TabChar::Jtt.val(),
|
|
};
|
|
|
|
// Right side
|
|
let rs = match pos {
|
|
models::Position::Top => models::TabChar::Jtr.val(),
|
|
models::Position::Middle => models::TabChar::Jr.val(),
|
|
models::Position::Bottom => models::TabChar::Jbr.val(),
|
|
};
|
|
|
|
// Right side before big cell
|
|
let rs_bbc = models::TabChar::Jr.val();
|
|
// Right side big cell before big cell
|
|
let rsbc_bbc = models::TabChar::Bv.val();
|
|
// Right side big cell
|
|
let rsbc = models::TabChar::Jl.val();
|
|
|
|
let line = models::TabChar::Bh.val().to_string().repeat(cell_length);
|
|
let line_h = models::TabChar::Bh
|
|
.val()
|
|
.to_string()
|
|
.repeat(cell_length_hours);
|
|
|
|
// Hours column
|
|
match skip_with.get(&0) {
|
|
Some(_) => print!("\n{}{}{}", ls, line_h, rs_bbc),
|
|
None => print!("\n{}{}{}", ls, line_h, ms),
|
|
};
|
|
|
|
// Courses columns
|
|
for i in 0..number_cell - 2 {
|
|
// Check if it's a big cell
|
|
match skip_with.get(&i) {
|
|
Some(text) => match skip_with.get(&(i + 1)) {
|
|
// Match check if the next cell will be big
|
|
Some(_) => print!("{:^cell_length$}{}", text, rsbc_bbc),
|
|
None => print!("{:^cell_length$}{}", text, rsbc),
|
|
},
|
|
None => match skip_with.get(&(i + 1)) {
|
|
// Match check if the next cell will be big
|
|
Some(_) => print!("{}{}", line, rs_bbc),
|
|
None => print!("{}{}", line, ms),
|
|
},
|
|
}
|
|
}
|
|
println!("{}{}", line, rs);
|
|
}
|
|
|
|
// Split a string in half with respect of words
|
|
pub fn split_half(text: &str) -> (&str, &str) {
|
|
let mid = text.len() / 2;
|
|
for (i, j) in (mid..text.len()).enumerate() {
|
|
if text.as_bytes()[j] == b' ' {
|
|
return text.split_at(mid + i);
|
|
}
|
|
}
|
|
|
|
text.split_at(mid)
|
|
}
|
|
|
|
|
|
// Reduce size of string by adding etc. to it, and cutting some info
|
|
pub fn etc_str(text: &str) -> String {
|
|
format!("{}...", split_half(text).0.trim())
|
|
}
|