#include "config.h"
#include "paths.h"
#include "runner.h"

#include <iostream>
#include <string>
#include <vector>

int main(int argc, char **argv) {
    if (argc < 3 || std::string(argv[1]) != "--config") {
        std::cerr << "Usage: mmas --config path/to/config.ini\n";
        return 1;
    }

    Config cfg;
    try {
        cfg = parse_config(argv[2]);
    } catch (const std::exception &e) {
        std::cerr << "Config error: " << e.what() << "\n";
        return 1;
    }

    int n = cfg.num_nodes > 0 ? cfg.num_nodes : infer_n_from_filename(cfg.data_file);
    if (n <= 0) {
        std::cerr << "Failed to infer num_nodes; set num_nodes in config.\n";
        return 1;
    }

    bool multi_heatmap = (cfg.heatmap_mode == "threshold")
                         && cfg.heatmap_type.empty()
                         && cfg.heatmap_dir.empty();
    if (multi_heatmap) {
        std::vector<std::string> types;
        try {
            types = list_heatmap_types(cfg.heatmap_root);
        } catch (const std::exception &e) {
            std::cerr << "Heatmap error: " << e.what() << "\n";
            return 1;
        }
        if (types.empty()) {
            std::cerr << "No heatmap types found under " << cfg.heatmap_root << "\n";
            return 1;
        }
        for (const auto &type : types) {
            Config run_cfg = cfg;
            run_cfg.heatmap_type = type;
            run_cfg.heatmap_dir = type;
            if (!cfg.output_dir.empty()) {
                run_cfg.output_dir = default_output_dir(run_cfg, n, cfg.output_dir);
            } else {
                run_cfg.output_dir.clear();
            }
            int rc = run_with_config(run_cfg, n);
            if (rc != 0) {
                return rc;
            }
        }
        return 0;
    }

    return run_with_config(cfg, n);
}
