From: MegaBrutal <megabrutal+github@megabrutal.com> Date: Sat, 18 Feb 2023 03:25:00 +0000 (+0100) Subject: Consolidate results to one struct X-Git-Tag: v0.2.0~7 X-Git-Url: http://git.megabrutal.com/?a=commitdiff_plain;h=d9facf526fc0f13449c9f11934e2380f673c09d9;p=hlquery.git Consolidate results to one struct --- diff --git a/src/main.rs b/src/main.rs index 468c5e2..7821521 100644 --- a/src/main.rs +++ b/src/main.rs @@ -2,11 +2,28 @@ use std::fmt; use std::fmt::Display; use std::error::Error; use std::env::args; -use std::net::{SocketAddr, ToSocketAddrs}; +use std::net::{SocketAddr, SocketAddrV4, ToSocketAddrs}; use serde::{Serialize, Serializer}; use a2s::A2SClient; use crate::HLQueryError::A2SError; +#[derive(Debug, Serialize)] +struct HLQueryResult { + info: Result<a2s::info::Info, HLQueryError>, + rules: Result<Vec<a2s::rules::Rule>, HLQueryError>, + players: Result<Vec<a2s::players::Player>, HLQueryError> +} + +impl HLQueryResult { + fn new(a2s_client: &A2SClient, server: SocketAddrV4) -> Self { + Self { + info: a2s_client.info(server).map_err(From::from), + rules: a2s_client.rules(server).map_err(From::from), + players: a2s_client.players(server).map_err(From::from) + } + } +} + #[derive(Debug)] enum HLQueryError { A2SError(a2s::errors::Error) @@ -52,13 +69,7 @@ fn main() { println!("Querying address: {}", address); - let result: Result<a2s::info::Info, HLQueryError> = client.info(address).map_err(From::from); - println!("{}\n", serde_json::to_string_pretty(&result).unwrap()); - - let result: Result<Vec<a2s::rules::Rule>, HLQueryError> = client.rules(address).map_err(From::from); - println!("{}\n", serde_json::to_string_pretty(&result).unwrap()); - - let result: Result<Vec<a2s::players::Player>, HLQueryError> = client.players(address).map_err(From::from); + let result = HLQueryResult::new(&client, address); println!("{}\n", serde_json::to_string_pretty(&result).unwrap()); }