import os
import subprocess
from plip.structure.preparation import PDBComplex
import pdb


def convert_pdbqt_to_pdb(pdbqt_path, output_pdb_path):
    run_line = 'obabel %s -O %s' % (pdbqt_path, output_pdb_path)
    result = subprocess.check_output(run_line.split(),
                                        stderr=subprocess.STDOUT,
                                        universal_newlines=True)


def merge_protein_ligand(protein_pdb, ligand_pdb, output_pdb):
    with open(output_pdb, 'w') as fout:
        with open(protein_pdb, 'r') as fprot:
            for line in fprot:
                if line.startswith(('ATOM', 'HETATM')):
                    fout.write(line)
        
        with open(ligand_pdb, 'r') as flig:
            for line in flig:
                if line.startswith(('ATOM', 'HETATM')):
                    if line.startswith('ATOM'):
                        line = 'HETATM' + line[6:]
                    fout.write(line)
        
        fout.write('END\n')

def analyze_plip_interactions(complex_pdb):
    protlig = PDBComplex()
    protlig.load_pdb(complex_pdb)
    protlig.analyze()
    pdb.set_trace()

    print("len(protlig.interaction_sets):", len(protlig.interaction_sets))
    result = {}
    for key, interactions in protlig.interaction_sets.items():
        ligand_id = key[:3] # ligand resname
        result[ligand_id] = {
            "hydrogen_bonds": len(interactions.hbonds_ldon) + len(interactions.hbonds_pdon),
            "hydrophobic": len(interactions.hydrophobic_contacts),
            "pi_stackings": len(interactions.pistacking),
            "water_bridges": len(interactions.water_bridges),
            "salt_bridges": len(interactions.saltbridge_lneg) + len(interactions.saltbridge_pneg),
            "metal_complexes": len(interactions.metal_complexes),
            "halogen_bonds": len(interactions.halogen_bonds),
        }

    return result

def detail_plip_interactions(complex_pdb):
    complex = PDBComplex()
    complex.load_pdb(complex_pdb)
    
    for ligand in complex.ligands:
        complex.characterize_complex(ligand)

        for interaction in complex.interaction_sets[ligand].all_itypes:
            print(interaction.__class__.__name__)   
            print(interaction.resnr, interaction.reschain, interaction.restype)  
            print(interaction.resatom)             
            print(interaction.ligatom)            
            print(interaction.distance)        


