Content-type: text/html
Man page of LCG_GET_CHECKSUM
LCG_GET_CHECKSUM
Section: Library Functions (3)
Updated: $Date: 2009/04/03 14:42:08 $
Index
Return to Main Contents
NAME
lcg_get_checksum - Get/compute checksum value of given files
SYNOPSIS
#include "lcg_util.h"
int lcg_get_checksum (int nbfiles,
char **files,
enum se_type defaulttype,
enum se_type setype,
int nobdii,
int force,
char *vo,
enum gfal_cksm_type cksmtype,
lcg_checksum **checksums,
char *errbuf,
int errbufsz);
DESCRIPTION
lcg_get_checksum
gets, or compute the checksum value of given files.
- nbfiles
-
specifies the number of elements in
files.
- files
-
specifies a list of files of size
nbfiles.
- defaulttype
-
specifies the default SE type you want to use. Possible values are
TYPE_NONE,
TYPE_SE,
TYPE_SRM,
TYPE_SRMv2,
for respectively no default type, classic SE, SRMv1, and SRMv2. But if according to the BDII the default type
is not available for this SE, it will use another type.
- setype
-
specifies the SE type you want to use for the source file. Possible values are
TYPE_NONE,
TYPE_SE,
TYPE_SRM,
TYPE_SRMv2,
for respectively no type, classic SE, SRMv1, and SRMv2. But if according to the BDII the default type
is not available for this SE, it will fail.
- nobdii
-
If set to a non-zero value, it means that you don't want to make BDII calls to get SE type. So, you must provide the type of the SE
for srm: arguments, and full endpoint in SURLs. For SE type,
defaulttype
can be used.
- force
-
If set to a non-zero value, it means that the checksum value won't be obtained from
srmLs
function (even if available there). So the value is obtained either from gridftp, or it is computed (for local files).
Note that some SEs support checksum through
srmLs
only, so this option may make the command fail in this case.
- vo
-
specifies the Virtual Organization the user belongs to. If it is not specified,
the environment variable LCG_GFAL_VO will be used.
- cksmtype
-
is the checksum type (algorithm) to use. Possible values are:
-
- GFAL_CKSM_NONE
-
default type will be used (Adler32)
- GFAL_CKSM_CRC32
-
CRC32 algorithm will be used
- GFAL_CKSM_ADLER32
-
Adler32 algorithm will be used
- GFAL_CKSM_MD5
-
MD5 algorithm will be used
- GFAL_CKSM_SHA1
-
SHA-1 algorithm will be used
- checksums
-
It is an out argument to show the status of each each file, with possibly an explanation.
So this is a pointer to a table of structures, which contains the following fields:
-
-
- char *file
-
the file name
- int status
-
the status of the file, which is a value of errno
- char *explanation
-
an explanation of this status (can be NULL)
- char *checksum
-
checksum value of the file, if available/computable.
- errbuf
-
specifies a buffer of size
errbufsz
to receive detailed error messages. If this pointer is NULL, the message goes
to stderr. The pointer should not be NULL if the application is a daemon or is
multi-threaded.
NOTE
The environment variable LCG_GFAL_INFOSYS must point to the BDII, unless
nobdii
is set to a non-zero value.
To use the RLS as catalog instead of the LFC, the environment variable
LCG_CATALOG_TYPE must explicitely be set to "edg". By default, it is set to "lfc".
RETURN VALUE
This routine returns 0 if the operation was successful or -1 if the operation
failed. In the latter case,
errno
is set appropriately.
ERRORS
- ENOENT
-
The named file does not exist.
- EACCES
-
Permission denied.
- EFAULT
-
file
or
vo
is an invalid pointer.
- ECOMM
-
Communication error.
- ENAMETOOLONG
-
vo
is too long.
- EPROTONOSUPPORT
-
Access method not supported.
FILES
/opt/lcg/include/lcg_util.h
- /opt/lcg/lib/liblcg_util.so
-
SEE ALSO
lcg_aa(3),
lcg_cp(3),
lcg_cr(3),
lcg_del(3),
lcg_gt(3),
lcg_la(3),
lcg_lg(3),
lcg_lr(3),
lcg_ra(3),
lcg_rep(3),
lcg_rf(3),
lcg_sd(3),
lcg_stmd(3),
lcg_uf(3)
Index
- NAME
-
- SYNOPSIS
-
- DESCRIPTION
-
- NOTE
-
- RETURN VALUE
-
- ERRORS
-
- FILES
-
- SEE ALSO
-
This document was created by
man2html,
using the manual pages.
Time: 14:16:52 GMT, July 14, 2009