File: Rollback.java

package info (click to toggle)
bbmap 39.20%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 26,024 kB
  • sloc: java: 312,743; sh: 18,099; python: 5,247; ansic: 2,074; perl: 96; makefile: 39; xml: 38
file content (46 lines) | stat: -rwxr-xr-x 1,020 bytes parent folder | download | duplicates (4)
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
package assemble;

import stream.Read;
import structures.IntList;

public class Rollback {

	public Rollback(Read r){
		this(r, null);
	}

	public Rollback(Read r, IntList counts){
		id0=r.id;
		flags0=r.flags;
		bases0=r.bases.clone();
		quals0=(r.quality==null ? null : r.quality.clone());
		counts0=(counts==null ? null : counts.copy());
	}
	
	public void rollback(Read r){
		rollback(r, null);
	}
	
	public void rollback(Read r, IntList counts){
		r.id=id0;
		r.flags=flags0;
		if(r.length()==bases0.length){
			System.arraycopy(bases0, 0, r.bases, 0, bases0.length);
			if(quals0!=null){System.arraycopy(quals0, 0, r.quality, 0, quals0.length);}
			if(counts!=null){System.arraycopy(counts0.array, 0, counts.array, 0, counts0.size);}
		}else{
			r.bases=bases0;
			r.quality=quals0;
			if(counts!=null){
				counts.clear();
				counts.addAll(counts0);
			}
		}
	}
	
	final String id0;
	final int flags0;
	final byte[] bases0, quals0;
	public final IntList counts0;
	
}