MASA-Core
ReversedCellsReader.cpp
Go to the documentation of this file.
00001 /*******************************************************************************
00002  *
00003  * Copyright (c) 2010-2015   Edans Sandes
00004  *
00005  * This file is part of MASA-Core.
00006  * 
00007  * MASA-Core is free software: you can redistribute it and/or modify
00008  * it under the terms of the GNU General Public License as published by
00009  * the Free Software Foundation, either version 3 of the License, or
00010  * (at your option) any later version.
00011  * 
00012  * MASA-Core is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00015  * GNU General Public License for more details.
00016  * 
00017  * You should have received a copy of the GNU General Public License
00018  * along with MASA-Core.  If not, see <http://www.gnu.org/licenses/>.
00019  *
00020  ******************************************************************************/
00021 
00022 #include "ReversedCellsReader.hpp"
00023 
00024 #include <stdio.h>
00025 
00026 ReversedCellsReader::ReversedCellsReader(SeekableCellsReader* reader) {
00027         this->reader = reader;
00028         this->position = position;
00029 }
00030 
00031 ReversedCellsReader::~ReversedCellsReader() {
00032         close();
00033 }
00034 
00035 void ReversedCellsReader::close() {
00036         if (reader == NULL) {
00037                 reader->close();
00038                 reader = NULL;
00039         }
00040 }
00041 
00042 int ReversedCellsReader::getType() {
00043         return INIT_WITH_CUSTOM_DATA;
00044 }
00045 
00046 int ReversedCellsReader::read(cell_t* buf, int len) {
00047         if (len > position) {
00048                 len = position;
00049         }
00050         position -= len;
00051         reader->seek(position);
00052         reader->read(buf, len);
00053 
00054         // Reverse buffer order
00055         for (int i=0; i<len/2; i++) {
00056                 cell_t aux = buf[i];
00057                 buf[i] = buf[len-1-i];
00058                 buf[len-1-i] = aux;
00059         }
00060 
00061         return len;
00062 }
00063 
00064 
00065 void ReversedCellsReader::seek(int position) {
00066         this->position = position;
00067 }
00068 
00069 int ReversedCellsReader::getOffset() {
00070         return position;
00071 }