Bioplib
Protein Structure C Library
 All Data Structures Files Functions Variables Typedefs Macros Pages
FindAtomInRes.c
Go to the documentation of this file.
1 /************************************************************************/
2 /**
3 
4  \file FindAtomInRes.c
5 
6  \version V1.11
7  \date 07.07.14
8  \brief PDB linked list manipulation
9 
10  \copyright (c) UCL / Dr. Andrew C. R. Martin 1992-6
11  \author Dr. Andrew C. R. Martin
12  \par
13  Institute of Structural & Molecular Biology,
14  University College London,
15  Gower Street,
16  London.
17  WC1E 6BT.
18  \par
19  andrew@bioinf.org.uk
20  andrew.martin@ucl.ac.uk
21 
22 **************************************************************************
23 
24  This code is NOT IN THE PUBLIC DOMAIN, but it may be copied
25  according to the conditions laid out in the accompanying file
26  COPYING.DOC.
27 
28  The code may be modified as required, but any modifications must be
29  documented so that the person responsible can be identified.
30 
31  The code may not be sold commercially or included as part of a
32  commercial product except as described in the file COPYING.DOC.
33 
34 **************************************************************************
35 
36  Description:
37  ============
38 
39 
40 **************************************************************************
41 
42  Usage:
43  ======
44 
45 **************************************************************************
46 
47  Revision History:
48  =================
49 - V1.0 22.02.94 Original release
50 - V1.1 23.05.94 Added FindNextChainPDB()
51 - V1.2 05.10.94 KillSidechain() uses BOOL rather than int
52 - V1.3 24.07.95 Added TermPDB()
53 - V1.4 25.07.95 Added GetPDBChainLabels()
54 - V1.5 26.09.95 Fixed bug in TermPDB()
55 - V1.6 12.10.95 Added DupePDB(), CopyPDBCoords()
56 - V1.7 23.10.95 Moved FindResidueSpec() to ParseRes.c
57 - V1.8 10.01.96 Added ExtractZonePDB()
58 - V1.9 14.03.96 Added FindAtomInRes()
59 - V1.10 08.10.99 Initialised some variables
60 - V1.11 07.07.14 Use bl prefix for functions By: CTP
61 
62 *************************************************************************/
63 /* Doxygen
64  -------
65  #GROUP Handling PDB Data
66  #SUBGROUP Searching the PDB linked list
67  #FUNCTION blFindAtomInRes()
68  Finds an atom within a residue
69 */
70 /************************************************************************/
71 /* Includes
72 */
73 #include <math.h>
74 #include <stdlib.h>
75 
76 #include "MathType.h"
77 #include "SysDefs.h"
78 #include "pdb.h"
79 #include "macros.h"
80 #include "general.h"
81 
82 /************************************************************************/
83 /* Defines and macros
84 */
85 
86 /************************************************************************/
87 /* Globals
88 */
89 
90 /************************************************************************/
91 /* Prototypes
92 */
93 
94 /************************************************************************/
95 /*>PDB *blFindAtomInRes(PDB *pdb, char *atnam_in)
96  ----------------------------------------------
97 *//**
98 
99  \param[in] *pdb The beginning of a residue in a PDB
100  linked list
101  \param[in] *atnam_in An atom name to search for (doesn't need
102  to be space-padded)
103  \return Pointer to required atom, NULL if not
104  found
105 
106  Finds an atom within a residue
107 
108 - 14.03.96 Original By: ACRM
109 - 07.07.14 Use bl prefix for functions By: CTP
110 */
111 PDB *blFindAtomInRes(PDB *pdb, char *atnam_in)
112 {
113  PDB *end,
114  *p;
115 
116  char atnam[8];
117 
118  /* First copy the specified atom name and pad to 4 chars */
119  strcpy(atnam,atnam_in);
120  blPadterm(atnam,4);
121 
122  /* Find the end of this residue */
123  end = blFindNextResidue(pdb);
124 
125  /* Search for the required atom */
126  for(p=pdb; p!=end; NEXT(p))
127  {
128  if(!strncmp(p->atnam,atnam,4))
129  return(p);
130  }
131 
132  return(NULL);
133 }
Include file for PDB routines.
#define NULL
Definition: array2.c:99
Definition: pdb.h:298
void blPadterm(char *string, int length)
Definition: padterm.c:117
#define NEXT(x)
Definition: macros.h:249
Useful macros.
char atnam[8]
Definition: pdb.h:316
Header file for general purpose routines.
System-type variable type definitions.
PDB * blFindNextResidue(PDB *pdb)
PDB * blFindAtomInRes(PDB *pdb, char *atnam_in)
Type definitions for maths.