summaryrefslogblamecommitdiffstats
path: root/src/main.rs
blob: 55e172586bab95c442601be1a6ca23e931421d8f (plain) (tree)
1
2
3
4
5
6
7
8

                  
                         
            
                     
                       
                     
                      



                          
 
        
             
           


          
                                                       
                                            




                                           
                                                         
 
                                              



                                                    
                                                                                              

      
                                        
 
                                    



          






                                          
                                                











                                                              
                 













                                                                              
 
#[macro_use]
extern crate clap;
extern crate directories;
#[macro_use]
extern crate failure;
extern crate indicatif;
extern crate reqwest;
extern crate rusqlite;
extern crate serde;
extern crate serde_json;
#[macro_use]
extern crate serde_derive;

mod cli;
mod exporter;
mod lastfm;
mod paths;
mod db;

fn sync(opts: &cli::Options) -> failure::Fallible<()> {
    let db = db::DB::new(&paths::dbpath())?;
    let lastfm = lastfm::LastFMClient::new(
        opts.api_key.as_ref().unwrap(),
        opts.username.as_ref().unwrap()
    );

    let exporter = exporter::Exporter::new(&db, &lastfm);

    let to_fetch = exporter.tracks_to_sync()?;
    let bar = indicatif::ProgressBar::new(to_fetch);
    bar.set_style(
        indicatif::ProgressStyle::default_bar()
            .progress_chars("=> ")
            .template("Downloading {pos}/{len} tracks...\n{percent:>3}% [{wide_bar}] {eta:5}")
    );

    exporter.sync(|_| { bar.inc(1); })?;

    bar.finish_with_message("done");

    Ok(())
}

fn run() -> failure::Fallible<()> {
    let opts = cli::get_options()?;
    match opts.command {
        cli::Command::Sync => sync(&opts),
    }
}

fn program_name() -> failure::Fallible<String> {
    let program = std::env::args()
        .next()
        .ok_or_else(|| format_err!("no program name found"))?;
    let path = std::path::Path::new(&program);
    let filename = path.file_name()
        .ok_or_else(|| format_err!("invalid filename found"))?
        .to_string_lossy()
        .to_string();
    Ok(filename)
}

fn main() {
    match run() {
        Ok(_) => {},
        Err(e) => {
            let name = program_name()
                .unwrap_or_else(|e| {
                    eprintln!("{}", e);
                    "?".to_string()
                });
            let cause = e
                .iter_chain()
                .fold(String::new(), |acc, x| acc + ": " + &format!("{}", x));
            eprintln!("{}{}", name, cause);
            std::process::exit(1);
        }
    }
}