/*
* International Union of Pure and Applied Chemistry (IUPAC)
* International Chemical Identifier (InChI)
* Version 1
* Software version 1.01
* July 21, 2006
* Developed at NIST
*/
#ifndef __INCHICANO_H__
#define __INCHICANO_H__
#ifndef INCHI_ALL_CPP
#ifdef __cplusplus
extern "C" {
#endif
#endif
int GetCanonLengths( int num_at, sp_ATOM* at, ATOM_SIZES *s, T_GROUP_INFO *t_group_info );
int AllocateCS( CANON_STAT *pCS, int num_at, int num_at_tg, int nLenCT, int nLenCTAtOnly,
int nLenLinearCTStereoDble, int nLenLinearCTIsotopicStereoDble,
int nLenLinearCTStereoCarb, int nLenLinearCTIsotopicStereoCarb,
int nLenLinearCTTautomer, int nLenLinearCTIsotopicTautomer,
int nLenIsotopic, INCHI_MODE nMode, BCN *pBCN );
int DeAllocateCS( CANON_STAT *pCS );
void DeAllocBCN( BCN *pBCN );
int Canon_INChI( int num_atoms, int num_at_tg, sp_ATOM* at, CANON_STAT* pCS, INCHI_MODE nMode, int bTautFtcn);
int GetBaseCanonRanking( int num_atoms, int num_at_tg, sp_ATOM* at[],
T_GROUP_INFO *t_group_info, ATOM_SIZES s[], BCN *pBCN, struct tagInchiTime *ulTimeOutTime );
int bCanonIsFinerThanEquitablePartition( int num_atoms, sp_ATOM* at, AT_RANK *nSymmRank );
int UpdateFullLinearCT( int num_atoms, int num_at_tg, sp_ATOM* at, AT_RANK *nRank, AT_RANK *nAtomNumber,
CANON_STAT* pCS, int bFirstTime );
int FixCanonEquivalenceInfo( int num_at_tg, AT_RANK *nSymmRank, AT_RANK *nCurrRank,
AT_RANK *nTempRank, AT_NUMB *nAtomNumber, int *bChanged);
#ifndef INCHI_ALL_CPP
#ifdef __cplusplus
}
#endif
#endif
#endif /* __INCHICANO_H__ */
syntax highlighted by Code2HTML, v. 0.9.1