MASA-Core
CrosspointsFile.hpp
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 #ifndef _CROSSPOINTSFILE_HPP
00023 #define _CROSSPOINTSFILE_HPP
00024 
00025 #include <stdio.h>
00026 #include <vector>
00027 #include <string>
00028 using namespace std;
00029 
00030 #include "Crosspoint.hpp"
00031 
00032 class CrosspointsFile : public std::vector<crosspoint_t> {
00033     public:
00034         CrosspointsFile ( string filename );
00035         virtual ~CrosspointsFile();
00036         void loadCrosspoints();
00037         void reverse(int seq0_len, int seq1_len);
00038 
00039         void setAutoSave();
00040         void write ( int i, int j, int score, int type );
00041         void write(crosspoint_t crosspoint);
00042         void close();
00043 
00044         void writeToFile( string filename );
00045 
00046         void save();
00047 
00048         int getLargestPartitionSize(int* max_i=NULL, int* max_j=NULL);
00049     private:
00050         string filename;
00051         string tmpFilename;
00052         FILE* file;
00053         bool autoSave;
00054 
00055         void open();
00056 };
00057 
00058 #endif  /* _CROSSPOINTSFILE_HPP */
00059