Bioplib
Protein Structure C Library
 All Data Structures Files Functions Variables Typedefs Macros Pages
CopyPDBCoords.c
Go to the documentation of this file.
1 /************************************************************************/
2 /**
3 
4  \file CopyPDBCoords.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 blCopyPDBCoords()
67  Applies the coordinates of one PDB linked list to another.
68  Assumes that the structures
69  are equivalent with identical atom ordering. Makes a simple check on
70  resnam and atnam at each position.
71 */
72 /************************************************************************/
73 /* Includes
74 */
75 #include <math.h>
76 #include <stdlib.h>
77 
78 #include "MathType.h"
79 #include "SysDefs.h"
80 #include "pdb.h"
81 #include "macros.h"
82 #include "general.h"
83 
84 /************************************************************************/
85 /* Defines and macros
86 */
87 
88 /************************************************************************/
89 /* Globals
90 */
91 
92 /************************************************************************/
93 /* Prototypes
94 */
95 
96 /************************************************************************/
97 /*>BOOL blCopyPDBCoords(PDB *out, PDB *in)
98  ---------------------------------------
99 *//**
100 
101  \param[in] *in Input PDB linked list
102  \param[out] *out Output PDB linked list
103  \return Success?
104 
105  Applies the coordinates of `in' to `out'. Assumes that the structures
106  are equivalent with identical atom ordering. Makes a simple check on
107  resnam and atnam at each position.
108 
109 - 11.10.95 Original By: ACRM
110 - 07.07.14 Use bl prefix for functions By: CTP
111 */
113 {
114  PDB *p, *q;
115 
116  for(p=in, q=out; p!=NULL && q!=NULL; NEXT(p), NEXT(q))
117  {
118  if(strncmp(p->atnam, q->atnam, 4) ||
119  strncmp(p->resnam, q->resnam, 4))
120  return(FALSE);
121 
122  q->x = p->x;
123  q->y = p->y;
124  q->z = p->z;
125  }
126 
127  if(p!=NULL || q!=NULL)
128  return(FALSE);
129 
130  return(TRUE);
131 }
132 
133 
BOOL blCopyPDBCoords(PDB *out, PDB *in)
Include file for PDB routines.
short BOOL
Definition: SysDefs.h:64
#define NULL
Definition: array2.c:99
Definition: pdb.h:298
#define FALSE
Definition: macros.h:223
#define NEXT(x)
Definition: macros.h:249
Useful macros.
char atnam[8]
Definition: pdb.h:316
char resnam[8]
Definition: pdb.h:319
REAL z
Definition: pdb.h:300
#define TRUE
Definition: macros.h:219
Header file for general purpose routines.
System-type variable type definitions.
Type definitions for maths.
REAL x
Definition: pdb.h:300
REAL y
Definition: pdb.h:300