File: PrintBcc.cpp

package info (click to toggle)
kissplice 2.6.7-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 16,752 kB
  • sloc: cpp: 8,783; python: 1,618; perl: 389; sh: 72; makefile: 18
file content (91 lines) | stat: -rw-r--r-- 3,543 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/* ***************************************************************************
 *
 *                              KisSplice
 *      de-novo calling alternative splicing events from RNA-seq data.
 *
 * ***************************************************************************
 *
 * Copyright INRIA
 *  contributors :  Vincent Lacroix
 *                  Pierre Peterlongo
 *                  Gustavo Sacomoto
 *                  Vincent Miele
 *                  Alice Julien-Laferriere
 *                  David Parsons
 *
 * pierre.peterlongo@inria.fr
 * vincent.lacroix@univ-lyon1.fr
 *
 * This software is a computer program whose purpose is to detect alternative
 * splicing events from RNA-seq data.
 *
 * This software is governed by the CeCILL license under French law and
 * abiding by the rules of distribution of free software. You can  use,
 * modify and/ or redistribute the software under the terms of the CeCILL
 * license as circulated by CEA, CNRS and INRIA at the following URL
 * "http://www.cecill.info".

 * As a counterpart to the access to the source code and  rights to copy,
 * modify and redistribute granted by the license, users are provided only
 * with a limited warranty  and the software's author,  the holder of the
 * economic rights,  and the successive licensors  have only  limited
 * liability.

 * In this respect, the user's attention is drawn to the risks associated
 * with loading,  using,  modifying and/or developing or reproducing the
 * software by the user in light of its specific status of free software,
 * that may mean  that it is complicated to manipulate,  and  that  also
 * therefore means  that it is reserved for developers  and  experienced
 * professionals having in-depth computer knowledge. Users are therefore
 * encouraged to load and test the software's suitability as regards their
 * requirements in conditions enabling the security of their systems and/or
 * data to be ensured and,  more generally, to use and operate it in the
 * same conditions as regards security.
 *
 * The fact that you are presently reading this means that you have had
 * knowledge of the CeCILL license and that you accept its terms.
 */

#include <stdio.h>
#include "CGraph.h"
#include "BubbleEnumeration.h"

// Functor that print the bc on file
class Printer 
{
 private:
  FILE * _out_file;
 public:
  Printer(FILE * out_file)
  : _out_file(out_file) {}
  void operator()(FILE* in_file, int written_lines){
    char* buffer = new char[100 * MAX];      
    for (int i = 0; i < written_lines ; i++) {
      fgets(buffer, 100 * MAX, in_file);
      fputs(buffer, _out_file);
    }
    delete[] buffer;
  }
};

int main( int argc, char** argv )
{
  if ( argc < 8 ){
    fprintf( stderr, "Usage: %s infofile contents_file_edges contents_file_nodes basename_edges basename_nodes number_to_read output_file_edges output_file_nodes \n", argv[0] );
  exit( EXIT_FAILURE );
  }

  FILE *output_file_edge = fopen(argv[7], "w");
  //if (output_file_edge == NULL) { fprintf(stderr, "Problem opening %s!\n", argv[7]); exit(0); } 
  FILE *output_file_node = fopen(argv[8], "w");
  //if (output_file_node == NULL) { fprintf(stderr, "Problem opening %s!\n", argv[8]); exit(0); }  

  int required_sequence = atoi( argv[6] );

  Printer edgeprinter(output_file_edge);
  Printer nodeprinter(output_file_node);
  read_edges_and_nodes_withoptimIO<Printer,Printer>
    (argv[1],argv[2],argv[3],argv[4],argv[5],&required_sequence, edgeprinter, nodeprinter);
  fclose(output_file_edge);
  fclose(output_file_node);
}