File: SketchRecord.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 (59 lines) | stat: -rwxr-xr-x 1,577 bytes parent folder | download | duplicates (2)
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
package bin;

import json.JsonObject;
import shared.LineParserS2;
import structures.ByteBuilder;

public class SketchRecord extends BinObject {
	
	public SketchRecord(JsonObject hit) {
		setFrom(hit);
	}
	
	public void setFrom(JsonObject hit) {
		matches=hit.getLong("Matches").intValue();
		ani=hit.getDouble("ANI").floatValue();
		completeness=hit.getDouble("Complt").floatValue();
		contam=hit.getDouble("Contam").floatValue();
		taxid=hit.getLong("TaxID").intValue();
		taxName=hit.getString("taxName");
		genusTaxid=-1;//TODO, get from tree
	}
	
	public ByteBuilder toBytes() {
		ByteBuilder bb=new ByteBuilder();
		return appendTo(bb);
	}
	
	public ByteBuilder appendTo(ByteBuilder bb) {
		bb.append("ANI: ").append(ani, 2);
		bb.tab().append("Complt: ").append(completeness, 2);
		bb.tab().append("Contam: ").append(contam, 2);
		bb.tab().append("Matches: ").append(matches);
		bb.tab().append("TaxID: ").append(taxid);
		bb.tab().append("Name: ").append(shrink(taxName));
		return bb;
	}
	
	private static String shrink(String n) {
		if(n==null || n.length()<40) {return n;}
		ByteBuilder bb=new ByteBuilder();
		LineParserS2 lp=new LineParserS2(' ');
		lp.set(n);
		for(int i=0; i<4 && lp.hasMore(); i++) {
			if(bb.length>0) {bb.space();}
			bb.append(lp.parseString());
		}
		if(lp.hasMore()) {bb.append("...");}
		return (bb.length()<n.length() ? bb.toString() : n);
	}

	int matches=-1;
	float completeness=-1;
	float contam=-1;
	float ani=-1;
	int taxid=-1;
	int genusTaxid=-1;
	String taxName=null;
	
}