generated from ElnuDev/rust-project
use thiserror
This commit is contained in:
parent
9009ae9e24
commit
2c72d5fc15
16 changed files with 104 additions and 163 deletions
42
Cargo.lock
generated
42
Cargo.lock
generated
|
@ -410,12 +410,6 @@ dependencies = [
|
||||||
"unicode-xid",
|
"unicode-xid",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "convert_case"
|
|
||||||
version = "0.4.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "6245d59a3e82a7fc217c5828a6692dbc6dfb63a0c8c90495621f7b9d79704a0e"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "convert_case"
|
name = "convert_case"
|
||||||
version = "0.6.0"
|
version = "0.6.0"
|
||||||
|
@ -464,19 +458,6 @@ dependencies = [
|
||||||
"syn 2.0.28",
|
"syn 2.0.28",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "derive_more"
|
|
||||||
version = "0.99.17"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "4fb810d30a7c1953f91334de7244731fc3f3c10d7fe163338a35b9f640960321"
|
|
||||||
dependencies = [
|
|
||||||
"convert_case 0.4.0",
|
|
||||||
"proc-macro2",
|
|
||||||
"quote",
|
|
||||||
"rustc_version",
|
|
||||||
"syn 1.0.109",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "digest"
|
name = "digest"
|
||||||
version = "0.10.7"
|
version = "0.10.7"
|
||||||
|
@ -504,7 +485,7 @@ name = "dyesub"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"askama",
|
"askama",
|
||||||
"derive_more",
|
"err-derive",
|
||||||
"kle-serial",
|
"kle-serial",
|
||||||
"lazy_static",
|
"lazy_static",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
|
@ -526,7 +507,6 @@ name = "dyesub-tool"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"class_list",
|
"class_list",
|
||||||
"derive_more",
|
|
||||||
"kle-serial",
|
"kle-serial",
|
||||||
"lazy_static",
|
"lazy_static",
|
||||||
"leptos",
|
"leptos",
|
||||||
|
@ -534,6 +514,7 @@ dependencies = [
|
||||||
"strum",
|
"strum",
|
||||||
"strum_macros",
|
"strum_macros",
|
||||||
"svg-units",
|
"svg-units",
|
||||||
|
"thiserror",
|
||||||
"wasm-bindgen",
|
"wasm-bindgen",
|
||||||
"wasm-bindgen-futures",
|
"wasm-bindgen-futures",
|
||||||
"web-sys",
|
"web-sys",
|
||||||
|
@ -1111,7 +1092,7 @@ checksum = "0bdd7a21d20ca21bb12d67d050d4b0ad9973b156bce98f499f8b1789f11959dd"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"attribute-derive",
|
"attribute-derive",
|
||||||
"cfg-if",
|
"cfg-if",
|
||||||
"convert_case 0.6.0",
|
"convert_case",
|
||||||
"html-escape",
|
"html-escape",
|
||||||
"itertools",
|
"itertools",
|
||||||
"leptos_hot_reload",
|
"leptos_hot_reload",
|
||||||
|
@ -1712,15 +1693,6 @@ version = "1.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2"
|
checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "rustc_version"
|
|
||||||
version = "0.4.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "bfa0f585226d2e68097d4f95d113b15b83a82e819ab25717ec0590d9584ef366"
|
|
||||||
dependencies = [
|
|
||||||
"semver",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustix"
|
name = "rustix"
|
||||||
version = "0.38.8"
|
version = "0.38.8"
|
||||||
|
@ -1767,12 +1739,6 @@ version = "1.0.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "4c309e515543e67811222dbc9e3dd7e1056279b782e1dacffe4242b718734fb6"
|
checksum = "4c309e515543e67811222dbc9e3dd7e1056279b782e1dacffe4242b718734fb6"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "semver"
|
|
||||||
version = "1.0.18"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "b0293b4b29daaf487284529cc2f5675b8e57c61f70167ba415a463651fd6a918"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "serde"
|
name = "serde"
|
||||||
version = "1.0.183"
|
version = "1.0.183"
|
||||||
|
@ -1978,11 +1944,11 @@ dependencies = [
|
||||||
name = "svg-units"
|
name = "svg-units"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"err-derive",
|
|
||||||
"lazy_static",
|
"lazy_static",
|
||||||
"regex",
|
"regex",
|
||||||
"strum",
|
"strum",
|
||||||
"strum_macros",
|
"strum_macros",
|
||||||
|
"thiserror",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
|
|
@ -6,7 +6,6 @@ edition = "2021"
|
||||||
[dependencies]
|
[dependencies]
|
||||||
svg-units = { path = "../svg-units" }
|
svg-units = { path = "../svg-units" }
|
||||||
class_list = "0.1.1"
|
class_list = "0.1.1"
|
||||||
derive_more = "0.99.17"
|
|
||||||
kle-serial = "0.2.2"
|
kle-serial = "0.2.2"
|
||||||
lazy_static = "1.4.0"
|
lazy_static = "1.4.0"
|
||||||
leptos = { version = "0.4.8", features = ["csr", "nightly"] }
|
leptos = { version = "0.4.8", features = ["csr", "nightly"] }
|
||||||
|
@ -15,6 +14,7 @@ strum = "0.25.0"
|
||||||
strum_macros = "0.25.2"
|
strum_macros = "0.25.2"
|
||||||
wasm-bindgen = "0.2.87"
|
wasm-bindgen = "0.2.87"
|
||||||
wasm-bindgen-futures = "0.4.37"
|
wasm-bindgen-futures = "0.4.37"
|
||||||
|
thiserror = "1.0.47"
|
||||||
|
|
||||||
[dependencies.web-sys]
|
[dependencies.web-sys]
|
||||||
version = "0.3.64"
|
version = "0.3.64"
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
use std::error::Error;
|
||||||
|
|
||||||
use leptos::{html::Input, *};
|
use leptos::{html::Input, *};
|
||||||
use web_sys::File;
|
use web_sys::File;
|
||||||
|
|
||||||
|
@ -20,24 +22,15 @@ pub fn KeyboardFromFile(
|
||||||
Ok(keyboard) => {
|
Ok(keyboard) => {
|
||||||
set_result_message(Some(ResultMessageData {
|
set_result_message(Some(ResultMessageData {
|
||||||
title: "Success".to_owned(),
|
title: "Success".to_owned(),
|
||||||
message: view! { cx,
|
message: format!("Loaded KLE layout <b>{}</b> successfully!", &keyboard.metadata.name),
|
||||||
"Loaded KLE layout "<b>{&keyboard.metadata.name}</b>" successfully!"
|
|
||||||
}
|
|
||||||
.into_view(cx),
|
|
||||||
colorway: Colorway::Ok,
|
colorway: Colorway::Ok,
|
||||||
}));
|
}));
|
||||||
set_keyboard(Some(keyboard));
|
set_keyboard(Some(keyboard));
|
||||||
}
|
}
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
set_result_message(Some(ResultMessageData {
|
set_result_message(Some({
|
||||||
message: view! { cx,
|
let error: Box<dyn Error> = Box::new(err);
|
||||||
{
|
error.into()
|
||||||
err.to_string()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.into_view(cx),
|
|
||||||
title: <ReadKleError as Into<&str>>::into(err).to_string(),
|
|
||||||
colorway: Colorway::Bad,
|
|
||||||
}));
|
}));
|
||||||
file_input().unwrap().set_value("");
|
file_input().unwrap().set_value("");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
use std::error::Error;
|
||||||
|
|
||||||
use leptos::{html::Input, *};
|
use leptos::{html::Input, *};
|
||||||
use web_sys::SubmitEvent;
|
use web_sys::SubmitEvent;
|
||||||
|
|
||||||
|
@ -24,24 +26,15 @@ pub fn KeyboardFromWeb(
|
||||||
Ok(keyboard) => {
|
Ok(keyboard) => {
|
||||||
set_result_message(Some(ResultMessageData {
|
set_result_message(Some(ResultMessageData {
|
||||||
title: "Success".to_owned(),
|
title: "Success".to_owned(),
|
||||||
message: view! { cx,
|
message: format!("Loaded KLE layout <b>{}</b> successfully!", &keyboard.metadata.name),
|
||||||
"Loaded KLE layout "<b>{&keyboard.metadata.name}</b>" successfully!"
|
|
||||||
}
|
|
||||||
.into_view(cx),
|
|
||||||
colorway: Colorway::Ok,
|
colorway: Colorway::Ok,
|
||||||
}));
|
}));
|
||||||
set_keyboard(Some(keyboard));
|
set_keyboard(Some(keyboard));
|
||||||
}
|
}
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
set_result_message(Some(ResultMessageData {
|
set_result_message(Some({
|
||||||
message: view! { cx,
|
let error: Box<dyn Error> = Box::new(err);
|
||||||
{
|
error.into()
|
||||||
err.to_string()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.into_view(cx),
|
|
||||||
title: <FetchKleError as Into<&str>>::into(err).to_string(),
|
|
||||||
colorway: Colorway::Bad,
|
|
||||||
}));
|
}));
|
||||||
input_element().unwrap().set_value("");
|
input_element().unwrap().set_value("");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,29 @@
|
||||||
use class_list::class_list;
|
use class_list::class_list;
|
||||||
use leptos::*;
|
use leptos::*;
|
||||||
|
use std::error::Error;
|
||||||
|
|
||||||
use crate::models::Colorway;
|
use crate::models::Colorway;
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct ResultMessageData {
|
pub struct ResultMessageData {
|
||||||
pub title: String,
|
pub title: String,
|
||||||
pub message: View,
|
pub message: String,
|
||||||
pub colorway: Colorway,
|
pub colorway: Colorway,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl From<Box<dyn Error>> for ResultMessageData {
|
||||||
|
fn from(value: Box<dyn Error>) -> Self {
|
||||||
|
Self {
|
||||||
|
title: value.to_string(),
|
||||||
|
message: value
|
||||||
|
.source()
|
||||||
|
.map(|source| source.to_string())
|
||||||
|
.unwrap_or_else(|| "".to_string()),
|
||||||
|
colorway: Colorway::Bad,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[component]
|
#[component]
|
||||||
pub fn ResultMessage(cx: Scope, message: ReadSignal<Option<ResultMessageData>>) -> impl IntoView {
|
pub fn ResultMessage(cx: Scope, message: ReadSignal<Option<ResultMessageData>>) -> impl IntoView {
|
||||||
let (open, set_open) = create_signal(cx, true);
|
let (open, set_open) = create_signal(cx, true);
|
||||||
|
@ -24,7 +38,7 @@ pub fn ResultMessage(cx: Scope, message: ReadSignal<Option<ResultMessageData>>)
|
||||||
<div class=class_list!["box", colorway] style="position: relative">
|
<div class=class_list!["box", colorway] style="position: relative">
|
||||||
<strong class="block titlebar">{title}</strong>
|
<strong class="block titlebar">{title}</strong>
|
||||||
<button class="iconbutton" on:click=move |_| set_open(false) style="position: absolute; bottom: 0.5em; right: 0.5em">"×"</button>
|
<button class="iconbutton" on:click=move |_| set_open(false) style="position: absolute; bottom: 0.5em; right: 0.5em">"×"</button>
|
||||||
<p>{message}</p>
|
<p inner_html=message />
|
||||||
</div>
|
</div>
|
||||||
})}
|
})}
|
||||||
</Show>
|
</Show>
|
||||||
|
|
|
@ -1,22 +1,18 @@
|
||||||
use derive_more::From;
|
use thiserror::Error;
|
||||||
use strum_macros::IntoStaticStr;
|
|
||||||
use wasm_bindgen::JsValue;
|
use wasm_bindgen::JsValue;
|
||||||
|
|
||||||
#[derive(From, IntoStaticStr)]
|
use super::JsError;
|
||||||
|
|
||||||
|
#[derive(Error, Debug)]
|
||||||
pub enum FetchFileError {
|
pub enum FetchFileError {
|
||||||
#[strum(serialize = "Failed to fetch file")]
|
#[error("Failed to fetch file")]
|
||||||
Request(JsValue),
|
Request(#[from] JsError),
|
||||||
#[strum(serialize = "Failed to read fetched file to string")]
|
#[error("Failed to read fetched file to string")]
|
||||||
ReadToString,
|
ReadToString,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ToString for FetchFileError {
|
impl From<JsValue> for FetchFileError {
|
||||||
fn to_string(&self) -> String {
|
fn from(value: JsValue) -> Self {
|
||||||
use FetchFileError::*;
|
Self::Request(value.into())
|
||||||
match self {
|
|
||||||
Request(error) => error.as_string(),
|
|
||||||
_ => None,
|
|
||||||
}
|
|
||||||
.unwrap_or_else(|| "".to_string())
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,38 +1,13 @@
|
||||||
use derive_more::From;
|
use thiserror::Error;
|
||||||
use strum_macros::IntoStaticStr;
|
|
||||||
|
|
||||||
use super::FetchFileError;
|
use super::FetchFileError;
|
||||||
|
|
||||||
#[derive(From, IntoStaticStr)]
|
#[derive(Error, Debug)]
|
||||||
pub enum FetchKleError {
|
pub enum FetchKleError {
|
||||||
#[strum(
|
#[error("Invalid source. Must be KLE layout, gist URL, gist ID, or direct URL to JSON file")]
|
||||||
serialize = "Invalid source. Must be KLE layout, gist URL, gist ID, or direct URL to JSON file"
|
|
||||||
)]
|
|
||||||
InvalidSource,
|
InvalidSource,
|
||||||
#[strum(serialize = "Failed to fetch file")]
|
#[error("Failed to fetch file")]
|
||||||
FetchFile(FetchFileError),
|
FetchFile(#[from] FetchFileError),
|
||||||
#[strum(serialize = "Failed to parse KLE JSON")]
|
#[error("Failed to parse KLE JSON")]
|
||||||
Serde(serde_json::Error),
|
Serde(#[from] serde_json::Error),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ToString for FetchKleError {
|
|
||||||
fn to_string(&self) -> String {
|
|
||||||
use FetchKleError::*;
|
|
||||||
match self {
|
|
||||||
FetchFile(error) => Some(match error {
|
|
||||||
FetchFileError::Request(error_info) => {
|
|
||||||
let mut full_error = <&FetchFileError as Into<&str>>::into(error).to_string();
|
|
||||||
if let Some(error_info) = error_info.as_string() {
|
|
||||||
full_error.push_str(": ");
|
|
||||||
full_error.push_str(&error_info);
|
|
||||||
}
|
|
||||||
full_error
|
|
||||||
}
|
|
||||||
FetchFileError::ReadToString => error.to_string(),
|
|
||||||
}),
|
|
||||||
Serde(error) => Some(error.to_string()),
|
|
||||||
_ => None,
|
|
||||||
}
|
|
||||||
.unwrap_or_else(|| "".to_string())
|
|
||||||
}
|
|
||||||
}
|
|
12
dyesub-tool/src/error/jserror.rs
Normal file
12
dyesub-tool/src/error/jserror.rs
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
use thiserror::Error;
|
||||||
|
use wasm_bindgen::JsValue;
|
||||||
|
|
||||||
|
#[derive(Error, Debug)]
|
||||||
|
#[error("Error reported from JavaScript")]
|
||||||
|
pub struct JsError(JsValue);
|
||||||
|
|
||||||
|
impl From<JsValue> for JsError {
|
||||||
|
fn from(value: JsValue) -> Self {
|
||||||
|
Self(value)
|
||||||
|
}
|
||||||
|
}
|
|
@ -9,3 +9,6 @@ pub use fetchkle::FetchKleError;
|
||||||
|
|
||||||
mod readkle;
|
mod readkle;
|
||||||
pub use readkle::ReadKleError;
|
pub use readkle::ReadKleError;
|
||||||
|
|
||||||
|
mod jserror;
|
||||||
|
pub use jserror::JsError;
|
|
@ -1,24 +1,20 @@
|
||||||
use derive_more::From;
|
use thiserror::Error;
|
||||||
use strum_macros::IntoStaticStr;
|
|
||||||
use wasm_bindgen::JsValue;
|
use wasm_bindgen::JsValue;
|
||||||
|
|
||||||
#[derive(From, IntoStaticStr)]
|
use super::JsError;
|
||||||
|
|
||||||
|
#[derive(Error, Debug)]
|
||||||
pub enum ReadFileError {
|
pub enum ReadFileError {
|
||||||
#[strum(serialize = "No file chosen")]
|
#[error("No file chosen")]
|
||||||
NoFile,
|
NoFile,
|
||||||
#[strum(serialize = "Failed to open file")]
|
#[error("Failed to open file")]
|
||||||
TextAwait(JsValue),
|
TextAwait(#[from] JsError),
|
||||||
#[strum(serialize = "Failed to parse file to string")]
|
#[error("Failed to parse file to string")]
|
||||||
ParseToString,
|
ParseToString,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ToString for ReadFileError {
|
impl From<JsValue> for ReadFileError {
|
||||||
fn to_string(&self) -> String {
|
fn from(value: JsValue) -> Self {
|
||||||
use ReadFileError::*;
|
Self::TextAwait(value.into())
|
||||||
match self {
|
|
||||||
TextAwait(error) => error.as_string(),
|
|
||||||
_ => None,
|
|
||||||
}
|
|
||||||
.unwrap_or_else(|| "".to_string())
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,21 +1,11 @@
|
||||||
use derive_more::From;
|
use thiserror::Error;
|
||||||
use strum_macros::IntoStaticStr;
|
|
||||||
|
|
||||||
use super::ReadFileError;
|
use super::ReadFileError;
|
||||||
|
|
||||||
#[derive(From, IntoStaticStr)]
|
#[derive(Error, Debug)]
|
||||||
pub enum ReadKleError {
|
pub enum ReadKleError {
|
||||||
ReadFile(ReadFileError),
|
#[error("Failed to read file")]
|
||||||
#[strum(serialize = "Failed to parse KLE JSON")]
|
ReadFile(#[from] ReadFileError),
|
||||||
Serde(serde_json::Error),
|
#[error("Failed to parse KLE JSON")]
|
||||||
}
|
Serde(#[from] serde_json::Error),
|
||||||
|
}
|
||||||
impl ToString for ReadKleError {
|
|
||||||
fn to_string(&self) -> String {
|
|
||||||
use ReadKleError::*;
|
|
||||||
match self {
|
|
||||||
ReadFile(error) => error.to_string(),
|
|
||||||
Serde(error) => error.to_string(),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -8,7 +8,7 @@ edition = "2021"
|
||||||
[dependencies]
|
[dependencies]
|
||||||
svg-units = { path = "../svg-units" }
|
svg-units = { path = "../svg-units" }
|
||||||
askama = "0.12.0"
|
askama = "0.12.0"
|
||||||
derive_more = "0.99.17"
|
|
||||||
kle-serial = "0.2.2"
|
kle-serial = "0.2.2"
|
||||||
lazy_static = "1.4.0"
|
lazy_static = "1.4.0"
|
||||||
serde_json = "1.0.105"
|
serde_json = "1.0.105"
|
||||||
|
err-derive = "0.3.1"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
|
||||||
use askama::Template;
|
use askama::Template;
|
||||||
use derive_more::From;
|
use err_derive::Error;
|
||||||
use lazy_static::lazy_static;
|
use lazy_static::lazy_static;
|
||||||
|
|
||||||
use svg_units::{SVGMeasure, SVGUnit};
|
use svg_units::{SVGMeasure, SVGUnit};
|
||||||
|
@ -38,11 +38,14 @@ mod filters {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(From, Debug)]
|
#[derive(Error, Debug)]
|
||||||
pub enum Error {
|
pub enum Error {
|
||||||
Io(std::io::Error),
|
#[error(display = "I/O error")]
|
||||||
Template(askama::Error),
|
Io(#[cause] std::io::Error),
|
||||||
LayoutParse(serde_json::Error),
|
#[error(display = "Templating error")]
|
||||||
|
Template(#[cause] askama::Error),
|
||||||
|
#[error(display = "Failed to parse KLE JSON")]
|
||||||
|
LayoutParse(#[cause] serde_json::Error),
|
||||||
}
|
}
|
||||||
|
|
||||||
pub type Result<T> = std::result::Result<T, Error>;
|
pub type Result<T> = std::result::Result<T, Error>;
|
||||||
|
|
|
@ -66,7 +66,7 @@ Updating `cargoHash`:
|
||||||
pname = "dyesub-cli";
|
pname = "dyesub-cli";
|
||||||
version = "0.1.0";
|
version = "0.1.0";
|
||||||
buildAndTestSubdir = "dyesub-cli";
|
buildAndTestSubdir = "dyesub-cli";
|
||||||
cargoHash = "sha256-6nbUjVjroFp2KZEk0wDisCUw2e9GtVxFgsGZm8xEe2A=";
|
cargoHash = "sha256-3i+msqsUkNtVAx1eOZFftYRCDg+nVFZDhbdOIC8xvxM=";
|
||||||
meta = meta // {
|
meta = meta // {
|
||||||
description = "A tool for generating dye sublimation transfer sheet SVGs for Japanese thumb shift 拇指シフト keycaps.";
|
description = "A tool for generating dye sublimation transfer sheet SVGs for Japanese thumb shift 拇指シフト keycaps.";
|
||||||
};
|
};
|
||||||
|
|
|
@ -6,8 +6,8 @@ edition = "2021"
|
||||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
err-derive = "0.3.1"
|
|
||||||
lazy_static = "1.4.0"
|
lazy_static = "1.4.0"
|
||||||
regex = "1.9.3"
|
regex = "1.9.3"
|
||||||
strum = "0.25.0"
|
strum = "0.25.0"
|
||||||
strum_macros = "0.25.2"
|
strum_macros = "0.25.2"
|
||||||
|
thiserror = "1.0.47"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
use super::SVGUnit;
|
use super::SVGUnit;
|
||||||
use err_derive::Error;
|
|
||||||
use lazy_static::lazy_static;
|
use lazy_static::lazy_static;
|
||||||
use regex::Regex;
|
use regex::Regex;
|
||||||
|
use thiserror::Error;
|
||||||
use std::cmp::Ordering;
|
use std::cmp::Ordering;
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
use std::num::ParseFloatError;
|
use std::num::ParseFloatError;
|
||||||
|
@ -35,13 +35,13 @@ impl SVGMeasure {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Error)]
|
#[derive(Error, Debug)]
|
||||||
pub enum SVGMeasureParseError {
|
pub enum SVGMeasureParseError {
|
||||||
#[error(display = "Failed to parse measure number")]
|
#[error("Failed to parse measure number")]
|
||||||
ParseMeasure(#[source] ParseFloatError),
|
ParseMeasure(#[from] ParseFloatError),
|
||||||
#[error(display = "Failed to parse measure unit")]
|
#[error("Failed to parse measure unit")]
|
||||||
ParseUnit(#[source] ParseError),
|
ParseUnit(#[from] ParseError),
|
||||||
#[error(display = "Invalid measure format")]
|
#[error("Invalid measure format")]
|
||||||
Invalid,
|
Invalid,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue