forked from thegenemyers/DAZZ_DB
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDBupgrade.Sep.25.2014.c
96 lines (79 loc) · 2.48 KB
/
DBupgrade.Sep.25.2014.c
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
92
93
94
95
96
/*******************************************************************************************
*
* Interim code: upgrade previous db to have int's for pulse positions.
*
* Author: Gene Myers
* Date : September 2014
*
********************************************************************************************/
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include "DB.h"
#ifdef HIDE_FILES
#define PATHSEP "/."
#else
#define PATHSEP "/"
#endif
typedef struct
{ int origin; // Well #
uint16 beg; // First pulse
uint16 end; // Last pulse
int64 boff; // Offset (in bytes) of compressed read in 'bases' file, or offset of
// uncompressed bases in memory block
int64 coff; // Offset (in bytes) of compressed quiva streams in 'quiva' file
int flags; // QV of read + flags above
} HITS_OLD;
typedef struct
{ int origin; // Well #
int beg; // First pulse
int end; // Last pulse
int64 boff; // Offset (in bytes) of compressed read in 'bases' file, or offset of
// uncompressed bases in memory block
int64 coff; // Offset (in bytes) of compressed quiva streams in 'quiva' file
int flags; // QV of read + flags above
} HITS_NEW;
int main(int argc, char *argv[])
{ HITS_DB db;
FILE *nxfile, *ixfile;
char *pwd, *root;
int i;
if (argc != 2)
{ fprintf(stderr,"Usage: %s <path:db>\n",argv[0]);
exit (1);
}
pwd = PathTo(argv[1]);
root = Root(argv[1],".db");
ixfile = Fopen(Catenate(pwd,PATHSEP,root,".idx"),"r");
nxfile = Fopen(Catenate(pwd,PATHSEP,root,".ndx"),"w");
if (ixfile == NULL || nxfile == NULL)
exit (1);
free(pwd);
free(root);
if (fread(&db,sizeof(HITS_DB),1,ixfile) != 1)
SYSTEM_ERROR
fwrite(&db,sizeof(HITS_DB),1,nxfile);
fprintf(stderr,"Converting %d reads\n",db.ureads);
fflush(stderr);
for (i = 0; i < db.ureads; i++)
{ HITS_OLD orec;
HITS_NEW nrec;
if (i%10000 == 0)
{ fprintf(stderr," Processing %d\n",i);
fflush(stderr);
}
if (fread(&orec,sizeof(HITS_OLD),1,ixfile) != 1)
SYSTEM_ERROR
nrec.origin = orec.origin;
nrec.beg = orec.beg;
nrec.end = orec.end;
nrec.boff = orec.boff;
nrec.coff = orec.coff;
nrec.flags = orec.flags;
fwrite(&nrec,sizeof(HITS_NEW),1,nxfile);
}
fclose(ixfile);
fclose(nxfile);
exit (0);
}