|
MASA-Core
|
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
1.7.6.1