import os
import sys
sys.path.append('..')

from rdchiral.template_extractor import extract_from_reaction, extract_from_reaction_plus


def get_reaction_template(reaction, super_general=False, canonical=True):  # 这里输入的是化学字符串
    reactants, products = reaction.split('>>')

    reaction_dict = {'reactants': reactants,
                     "products": products,
                     '_id': 000}  # 这里是未来转换格式以适应extract_from_reaction需要的格式，然后可以得到template
    template = extract_from_reaction_plus(reaction=reaction_dict, super_general=super_general, canonical=canonical)

    return template


if __name__ == '__main__':
    rxn = "[Br:1][c:2]1[cH:3][c:4]([C:9]([F:10])([F:11])[F:12])[c:5]([OH:8])[n:6][cH:7]1.I[CH2:20][CH3:21]>>[Br:1][" \
          "c:2]1[cH:3][c:4]([C:9]([F:10])([F:11])[F:12])[c:5](=[O:8])[n:6]([CH2:20][CH3:21])[cH:7]1 "
    print('rxn: ', rxn)
    outcome = get_reaction_template(reaction=rxn, super_general=True, canonical=False)
    print('super_general=True, canonical=False ---------------')
    print(outcome)
    outcome = get_reaction_template(reaction=rxn, super_general=True, canonical=True)
    print('super_general=True, canonical=True ---------------')
    print(outcome)
    outcome = get_reaction_template(reaction=rxn, super_general=False, canonical=True)
    print('super_general=False, canonical=True ---------------')
    print(outcome)
    outcome = get_reaction_template(reaction=rxn, super_general=False, canonical=False)
    print('super_general=False, canonical=False ---------------')
    print(outcome)
