3 * This source code is part of
7 * GROningen MAchine for Chemical Simulations
10 * Written by David van der Spoel, Erik Lindahl, Berk Hess, and others.
11 * Copyright (c) 1991-2000, University of Groningen, The Netherlands.
12 * Copyright (c) 2001-2004, The GROMACS development team,
13 * check out http://www.gromacs.org for more information.
15 * This program is free software; you can redistribute it and/or
16 * modify it under the terms of the GNU General Public License
17 * as published by the Free Software Foundation; either version 2
18 * of the License, or (at your option) any later version.
20 * If you want to redistribute modifications, please consider that
21 * scientific software is very special. Version control is crucial -
22 * bugs must be traceable. We will be happy to consider code for
23 * inclusion in the official distribution, but derived work must not
24 * be called official GROMACS. Details are found in the README & COPYING
25 * files - if they are missing, get the official version at www.gromacs.org.
27 * To help us fund GROMACS development, we humbly ask that you cite
28 * the papers on the package - you can find them in the top README file.
30 * For more info, check our website at http://www.gromacs.org
33 * Gromacs Runs On Most of All Computer Systems
46 #ifdef __PGI /*Portland group compiler*/
47 #define int64_t long long
50 #if (defined WIN32 || defined _WIN32 || defined WIN64 || defined _WIN64 || defined __CYGWIN__ || defined __CYGWIN32__ || defined GMX_INTERNAL_XDR)
51 #include "gmx_system_xdr.h"
58 xdropen(XDR
*xdrs
, const char *filename
, const char *type
);
65 xdr_get_fp(int xdrid
);
68 /* Read or write reduced precision *float* coordinates */
70 xdr3dfcoord(XDR
*xdrs
, float *fp
, int *size
, float *precision
);
73 /* Read or write a *real* value (stored as float) */
75 xdr_real(XDR
*xdrs
,real
*r
);
78 /* Read or write reduced precision *real* coordinates */
80 xdr3drcoord(XDR
*xdrs
,real
*fp
,int *size
,real
*precision
);
83 extern int xdr_gmx_large_int(XDR
*xdrs
,gmx_large_int_t
*i
,const char *warn
);
84 /* Read or write a gmx_large_int_t value.
85 * 32bit code reading a 64bit gmx_large_int_t value from xdrs could
86 * lead to values out of int range.
87 * When warn!=NULL a warning will be written to stderr
88 * when a value does not fit,
90 * "WARNING during %s:", where warn is printed in %s.
94 xdr_xtc_estimate_dt(FILE *fp
, XDR
*xdrs
, int natoms
, bool * bOK
);
97 xdr_xtc_seek_time(real time
, FILE *fp
, XDR
*xdrs
, int natoms
);
101 xdr_xtc_seek_frame(int frame
, FILE *fp
, XDR
*xdrs
, int natoms
);
105 xdr_xtc_get_last_frame_time(FILE *fp
, XDR
*xdrs
, int natoms
, bool * bOK
);
109 xdr_xtc_get_last_frame_number(FILE *fp
, XDR
*xdrs
, int natoms
, bool * bOK
);