// ----------------------------------------------------------------------
// File: XrdCpAbort.cc
// Author: Andreas-Joachim Peters - CERN
// ----------------------------------------------------------------------
/************************************************************************
* EOS - the CERN Disk Storage System *
* Copyright (C) 2011 CERN/Switzerland *
* *
* This program is free software: you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation, either version 3 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program. If not, see .*
************************************************************************/
/*-----------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------*/
#include
#include
/*-----------------------------------------------------------------------------*/
XrdPosixXrootd posixXrootd;
int main (int argc, char* argv[]) {
// create a 1k file but does not close it!
XrdOucString urlFile = argv[1];
if (!urlFile.length()) {
fprintf(stderr,"usage: xrdcpabort \n");
exit(EINVAL);
}
struct stat buf;
if (!XrdPosixXrootd::Stat(urlFile.c_str(), &buf)) {
int fdRead = XrdPosixXrootd::Open(urlFile.c_str(),0,0);
if (fdRead>=0) {
char buffer[8192];
bool first=true;
for (long long offset = (buf.st_size - (buf.st_size%8192)); offset >0; offset -= 8192) {
int rbytes = XrdPosixXrootd::Pread(fdRead, buffer, (first && (buf.st_size%8192))? (buf.st_size%8192):8192, offset);
if (rbytes <= 0) {
fprintf(stderr,"error: read failed at offset %lld\n", offset);
exit(-1);
}
first = false;
}
int rc = XrdPosixXrootd::Close(fdRead);
if (rc) {
fprintf(stderr,"error: close failed\nd with retc=%d", rc);
exit(rc);
}
} else {
fprintf(stderr,"error: failed to open %s\n", urlFile.c_str());
}
} else {
fprintf(stderr,"error: file %s does not exist!\n", urlFile.c_str());
exit(-1);
}
}