Add error.rs

Signed-off-by: Maxime “pep” Buquet <pep@bouah.net>
This commit is contained in:
Maxime “pep” Buquet 2022-07-24 12:37:58 +02:00
parent 58d096ef13
commit 18178d81aa
Signed by: pep
GPG key ID: DEDA74AEECA9D0F2
2 changed files with 58 additions and 7 deletions

48
src/error.rs Normal file
View file

@ -0,0 +1,48 @@
// Copyright (C) 2022 Maxime “pep” Buquet <pep@bouah.net>
//
// This program is free software: you can redistribute it and/or modify it
// under the terms of the GNU Affero General Public License as published by the
// Free Software Foundation, either version 3 of the License, or (at your
// option) any later version.
//
// This program is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License
// for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
//
//
use std::convert::From;
use std::error::Error as StdError;
use mmdbus::dbus;
#[derive(Debug)]
pub enum Error {
DBusError(dbus::Error),
}
impl StdError for Error {
fn cause(&self) -> Option<&dyn StdError> {
match self {
Error::DBusError(e) => Some(e),
}
}
}
impl std::fmt::Display for Error {
fn fmt(&self, fmt: &mut std::fmt::Formatter) -> std::fmt::Result {
match self {
Error::DBusError(e) => write!(fmt, "dbus error: {}", e),
}
}
}
impl From<dbus::Error> for Error {
fn from(err: dbus::Error) -> Error {
Error::DBusError(err)
}
}

View file

@ -13,7 +13,10 @@
// You should have received a copy of the GNU Affero General Public License // You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
pub mod error;
pub mod mm; pub mod mm;
use error::Error;
use mm::modem::Modem as ModemAccess; use mm::modem::Modem as ModemAccess;
use std::fmt; use std::fmt;
@ -53,7 +56,7 @@ pub struct DBus {
} }
impl DBus { impl DBus {
pub fn connect() -> Result<Self, DBusError> { pub fn connect() -> Result<Self, Error> {
let (resource, conn) = connection::new_system_sync()?; let (resource, conn) = connection::new_system_sync()?;
let handle: JoinHandle<()> = tokio::spawn(async { let handle: JoinHandle<()> = tokio::spawn(async {
@ -78,11 +81,11 @@ pub struct ModemManager {
} }
impl ModemManager { impl ModemManager {
pub fn connect() -> Result<Self, DBusError> { pub fn connect() -> Result<Self, Error> {
DBus::connect().map(|dbus| Self { dbus }) DBus::connect().map(|dbus| Self { dbus })
} }
pub async fn modems(&self) -> Result<Vec<Modem>, DBusError> { pub async fn modems(&self) -> Result<Vec<Modem>, Error> {
let objects = self.dbus.proxy(MM_PATH).get_managed_objects().await?; let objects = self.dbus.proxy(MM_PATH).get_managed_objects().await?;
let modems = objects let modems = objects
.into_iter() .into_iter()
@ -111,7 +114,7 @@ impl fmt::Debug for Modem {
} }
impl Modem { impl Modem {
pub async fn enabled(&self) -> Result<bool, DBusError> { pub async fn enabled(&self) -> Result<bool, Error> {
let state: ModemState = ModemAccess::state(&self.dbus.proxy(&self.path)).await.map(Into::into)?; let state: ModemState = ModemAccess::state(&self.dbus.proxy(&self.path)).await.map(Into::into)?;
Ok(match state { Ok(match state {
ModemState::Enabling ModemState::Enabling
@ -124,8 +127,8 @@ impl Modem {
}) })
} }
pub async fn model(&self) -> Result<String, DBusError> { pub async fn model(&self) -> Result<String, Error> {
ModemAccess::model(&self.dbus.proxy(&self.path)).await ModemAccess::model(&self.dbus.proxy(&self.path)).await.map_err(Error::DBusError)
} }
} }
@ -178,7 +181,7 @@ impl From<i32> for ModemState {
} }
} }
async fn print_foo(mm: ModemManager) -> Result<(), DBusError> { async fn print_foo(mm: ModemManager) -> Result<(), Error> {
let modems = mm.modems().await?; let modems = mm.modems().await?;
println!("Modems: {:?}", modems); println!("Modems: {:?}", modems);
for modem in modems { for modem in modems {