// Copyright 2023 Christian Ulrich
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
//
// usage: ./part1 < input
use std::io;
pub struct CalibrationValues {
inner: Vec>,
}
impl CalibrationValues {
pub fn from_stdin() -> Result {
let mut values = vec![];
for line in io::stdin().lines() {
let digits = line
.unwrap()
.chars()
.filter(|c| c.is_digit(10))
.collect::>();
if digits.len() > 0 {
values.push(digits);
}
}
Ok(Self { inner: values })
}
pub fn iter(&mut self) -> std::slice::Iter<'_, Vec> {
self.inner.iter()
}
}
fn main() -> Result<(), &'static str> {
let mut values = CalibrationValues::from_stdin()?;
let mut sum = 0;
for digits in values.iter() {
sum += [*digits.first().unwrap(), *digits.last().unwrap()]
.iter()
.collect::()
.parse::()
.map_err(|_| "cannot parse calibration value")?;
}
println!("{sum}");
Ok(())
}