fFile = fopen(fileName, "rb");
if (!fFile) {
Error("AliRawReaderDate", "could not open file %s", fileName);
+ fIsValid = kFALSE;
return;
}
if (eventNumber < 0) return;
while (fread(&header, 1, headerSize, fFile) == headerSize) {
if (eventNumber == 0) {
UChar_t* buffer = new UChar_t[header.eventSize];
- fseek(fFile, -headerSize, SEEK_CUR);
+ fseek(fFile, -(long)headerSize, SEEK_CUR);
if (fread(buffer, 1, header.eventSize, fFile) != header.eventSize) break;
fEvent = (eventHeaderStruct*) buffer;
break;
#endif
}
+UInt_t AliRawReaderDate::GetTimestamp() const
+{
+// get the timestamp from the event header
+
+#ifdef ALI_DATE
+ if (!fEvent) return 0;
+ return fEvent->eventTimestamp;
+#else
+ return 0;
+#endif
+}
Int_t AliRawReaderDate::GetEquipmentSize() const
{
// "read" the data header
fHeader = (AliRawDataHeader*) fPosition;
if ((fPosition + fHeader->fSize) != fEnd) {
- Warning("ReadHeader",
- "raw data size found in the header is wrong (%d != %d)! Using the equipment size instead !",
- fHeader->fSize, fEnd - fPosition);
+ if (fHeader->fSize != 0xFFFFFFFF)
+ Warning("ReadHeader",
+ "raw data size found in the header is wrong (%d != %d)! Using the equipment size instead !",
+ fHeader->fSize, fEnd - fPosition);
fHeader->fSize = fEnd - fPosition;
}
fPosition += sizeof(AliRawDataHeader);
// go to the next event in the date file
#ifdef ALI_DATE
- if (!fFile) return kFALSE;
+ if (!fFile) {
+ if (fEventNumber < 0 && fEvent) {
+ fEventNumber++;
+ return kTRUE;
+ }
+ else
+ return kFALSE;
+ }
Reset();
eventHeaderStruct header;
continue;
}
UChar_t* buffer = new UChar_t[header.eventSize];
- fseek(fFile, -headerSize, SEEK_CUR);
+ fseek(fFile, -(long)headerSize, SEEK_CUR);
if (fread(buffer, 1, header.eventSize, fFile) != header.eventSize) {
Error("NextEvent", "could not read event from file");
delete[] buffer;
break;
}
fEvent = (eventHeaderStruct*) buffer;
+ fEventNumber++;
return kTRUE;
};
{
// go back to the beginning of the date file
- if (!fFile) return kFALSE;
+ if (fFile)
+ fseek(fFile, 0, SEEK_SET);
- fseek(fFile, 0, SEEK_SET);
+ fEventNumber = -1;
return Reset();
}
// check consistency of data size in the data header and in the sub event
AliRawDataHeader* header = (AliRawDataHeader*) position;
if ((position + header->fSize) != end) {
- Warning("ReadHeader",
- "raw data size found in the header is wrong (%d != %d)! Using the equipment size instead !",
- header->fSize, end - position);
+ if (header->fSize != 0xFFFFFFFF)
+ Warning("ReadHeader",
+ "raw data size found in the header is wrong (%d != %d)! Using the equipment size instead !",
+ header->fSize, end - position);
header->fSize = end - position;
result |= kErrSize;
}