summaryrefslogtreecommitdiffstats
path: root/ozone-cli/src/main.rs
blob: 4b04e480d56d81e68f4427957c38ee9893eee3bd (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
mod cli;

use std::error::Error;
use std::process::ExitCode;
use log::{error, info};
use clap::Parser;
use ozone::launcher::{Launcher, Settings};

use crate::cli::{Cli, ProfileCommand, RootCommand};

async fn main_inner(cli: Cli) -> Result<ExitCode, Box<dyn Error>> {
    let Some(home) = cli.home.or_else(Launcher::sensible_home) else {
        error!("Could not choose a launcher home directory. Please choose one with `--home'.");
        return Ok(ExitCode::FAILURE); // we print our own error message
    };

    info!("Sensible home could be {home:?}");
    let mut settings = Settings::load(home.join("ozone.json")).await?;

    match &cli.subcmd {
        RootCommand::Profile(p) => match p.command() {
            ProfileCommand::List => {
                for (name, profile) in settings.get_profiles().iter() {
                    println!("{name}: {profile:#?}");
                }
            },
            ProfileCommand::Create(args) => {
                if settings.profiles.contains_key(&args.name) {
                    eprintln!("A profile with that name already exists.");
                    return Ok(ExitCode::FAILURE);
                }

                if let Some(ref src) = args.clone {
                    if let Some(profile) = settings.get_profiles().get(src) {
                        let profile = profile.clone();
                        settings.profiles.insert(args.name.clone(), profile);
                    } else {
                        eprintln!("Unknown profile `{src}'.");
                        return Ok(ExitCode::FAILURE);
                    }

                    return Ok(ExitCode::SUCCESS);
                }

                // creating a new profile from scratch

            }
            _ => todo!()
        },
        RootCommand::Launch => {
            settings.save().await?;

            let launcher = Launcher::new(&home, !cli.offline).await?;
            let profile = settings.get_profiles().get("default").unwrap();

            let launch = launcher.prepare_launch(profile, settings.get_instances().get(profile.get_instance_name()).unwrap(), settings.get_client_id()).await.map_err(|e| {
                error!("error launching: {e}");
                e
            })?;

            dbg!(&launch);
            info!("ok");

            ozone::launcher::run_the_game(&launch)?;
        }
        _ => todo!()
    }

    Ok(ExitCode::SUCCESS)
}

#[tokio::main]
async fn main() -> ExitCode {
    simple_logger::SimpleLogger::new().env().init().unwrap();

    let arg = dbg!(Cli::parse());

    main_inner(arg).await.unwrap_or_else(|e| {
        error!("Launcher initialization error:");
        error!("{e}");

        ExitCode::FAILURE
    })

    /*let launcher = Launcher::new("./work", true).await?;

    */
}