""" """
import csv
import json
import os
from typing import List

from absl import app
from absl import flags

import numpy as np


###############################################################################

FLAGS = flags.FLAGS


flags.DEFINE_list('evaluation_filepaths_1', None, '')
flags.DEFINE_list('evaluation_filepaths_2', None, '')

###############################################################################
# Evaluation labels:
NO = 0
YES = 1
MAYBE = 2
###############################################################################


def _label_int_from_str(s: str) -> int:
    s = s.strip().lower()
    if s == 'no':
        return NO
    elif s == 'yes':
        return YES
    elif s == 'maybe':
        return MAYBE
    else:
        raise ValueError(s)


def _load_evaluations(filepaths: List[str]) -> np.ndarray:
    ret = []
    for filepath in filepaths:
        with open(os.path.expanduser(filepath), 'r') as f:
            cf = csv.reader(f)
            for i, row in enumerate(cf):
                # Skip the header.
                if i == 0:
                    continue
                ret.append(_label_int_from_str(row[1]))
    return np.array(ret, dtype=np.int64)


def _set_maybe_to(evaluations: np.ndarray, replacement: int) -> np.ndarray:
    # Returns a modified copy.
    evaluations = np.copy(evaluations)
    evaluations[evaluations == MAYBE] = replacement
    return evaluations

###############################################################################


def main(_):
    evaluations1 = _load_evaluations(FLAGS.evaluation_filepaths_1)
    evaluations2 = _load_evaluations(FLAGS.evaluation_filepaths_2)

    print('raw:', (evaluations1 == evaluations2).mean())
    print('maybe as yes:', (_set_maybe_to(evaluations1, YES) == _set_maybe_to(evaluations2, YES)).mean())

    #


if __name__ == "__main__":
    app.run(main)
