annotate lib/galaxy/datatypes/shear.py @ 0:65255beda972

Uploaded
author jjohnson
date Fri, 08 Nov 2013 16:23:10 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
65255beda972 Uploaded
jjohnson
parents:
diff changeset
1 import sys,os
65255beda972 Uploaded
jjohnson
parents:
diff changeset
2 import logging
65255beda972 Uploaded
jjohnson
parents:
diff changeset
3 import galaxy.datatypes.data
65255beda972 Uploaded
jjohnson
parents:
diff changeset
4 from galaxy.datatypes.data import Text
65255beda972 Uploaded
jjohnson
parents:
diff changeset
5 from galaxy.datatypes.metadata import MetadataElement
65255beda972 Uploaded
jjohnson
parents:
diff changeset
6
65255beda972 Uploaded
jjohnson
parents:
diff changeset
7 class ShearSvIndex( Text ):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
8 MetadataElement( name="base_name", desc="base name for this index set", default='shear_ref', set_in_upload=True, readonly=True )
65255beda972 Uploaded
jjohnson
parents:
diff changeset
9 """
65255beda972 Uploaded
jjohnson
parents:
diff changeset
10 generated files:
65255beda972 Uploaded
jjohnson
parents:
diff changeset
11 copy fasta:
65255beda972 Uploaded
jjohnson
parents:
diff changeset
12 base_name.fa
65255beda972 Uploaded
jjohnson
parents:
diff changeset
13 index fasta with samtools index:
65255beda972 Uploaded
jjohnson
parents:
diff changeset
14 base_name.fa.fai
65255beda972 Uploaded
jjohnson
parents:
diff changeset
15 create 2bit with faToTwoBit:
65255beda972 Uploaded
jjohnson
parents:
diff changeset
16 base_name.2bit
65255beda972 Uploaded
jjohnson
parents:
diff changeset
17 create bwa index:
65255beda972 Uploaded
jjohnson
parents:
diff changeset
18 base_name.fa.amb
65255beda972 Uploaded
jjohnson
parents:
diff changeset
19 base_name.fa.ann
65255beda972 Uploaded
jjohnson
parents:
diff changeset
20 base_name.fa.bwt
65255beda972 Uploaded
jjohnson
parents:
diff changeset
21 base_name.fa.pac
65255beda972 Uploaded
jjohnson
parents:
diff changeset
22 base_name.fa.rbwt
65255beda972 Uploaded
jjohnson
parents:
diff changeset
23 base_name.fa.rpac
65255beda972 Uploaded
jjohnson
parents:
diff changeset
24 base_name.fa.rsa
65255beda972 Uploaded
jjohnson
parents:
diff changeset
25 base_name.fa.sa
65255beda972 Uploaded
jjohnson
parents:
diff changeset
26 """
65255beda972 Uploaded
jjohnson
parents:
diff changeset
27 file_ext = 'shear.svidx'
65255beda972 Uploaded
jjohnson
parents:
diff changeset
28 composite_type = 'auto_primary_file'
65255beda972 Uploaded
jjohnson
parents:
diff changeset
29 allow_datatype_change = False
65255beda972 Uploaded
jjohnson
parents:
diff changeset
30
65255beda972 Uploaded
jjohnson
parents:
diff changeset
31 def __init__(self, **kwd):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
32 """Initialize datatype"""
65255beda972 Uploaded
jjohnson
parents:
diff changeset
33 Text.__init__( self, **kwd )
65255beda972 Uploaded
jjohnson
parents:
diff changeset
34
65255beda972 Uploaded
jjohnson
parents:
diff changeset
35 def init_meta( self, dataset, copy_from=None ):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
36 Text.init_meta( self, dataset, copy_from=copy_from )
65255beda972 Uploaded
jjohnson
parents:
diff changeset
37
65255beda972 Uploaded
jjohnson
parents:
diff changeset
38 def generate_primary_file( self, dataset = None ):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
39 """
65255beda972 Uploaded
jjohnson
parents:
diff changeset
40 This is called only at upload to write the html file
65255beda972 Uploaded
jjohnson
parents:
diff changeset
41 cannot rename the datasets here - they come with the default unfortunately
65255beda972 Uploaded
jjohnson
parents:
diff changeset
42 """
65255beda972 Uploaded
jjohnson
parents:
diff changeset
43
65255beda972 Uploaded
jjohnson
parents:
diff changeset
44 def regenerate_primary_file(self,dataset):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
45 """
65255beda972 Uploaded
jjohnson
parents:
diff changeset
46 cannot do this until we are setting metadata
65255beda972 Uploaded
jjohnson
parents:
diff changeset
47 """
65255beda972 Uploaded
jjohnson
parents:
diff changeset
48 bn = dataset.metadata.base_name
65255beda972 Uploaded
jjohnson
parents:
diff changeset
49 f = file(dataset.file_name,'w')
65255beda972 Uploaded
jjohnson
parents:
diff changeset
50 f.write(bn)
65255beda972 Uploaded
jjohnson
parents:
diff changeset
51 f.close()
65255beda972 Uploaded
jjohnson
parents:
diff changeset
52
65255beda972 Uploaded
jjohnson
parents:
diff changeset
53 def set_meta( self, dataset, overwrite = True, **kwd ):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
54 efp = dataset.extra_files_path
65255beda972 Uploaded
jjohnson
parents:
diff changeset
55 flist = os.listdir(efp)
65255beda972 Uploaded
jjohnson
parents:
diff changeset
56 for i,fname in enumerate(flist):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
57 if fname.endswith('.fa'):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
58 dataset.metadata.base_name = fname[:-3]
65255beda972 Uploaded
jjohnson
parents:
diff changeset
59 break
65255beda972 Uploaded
jjohnson
parents:
diff changeset
60 if fname.endswith('.2bit'):
65255beda972 Uploaded
jjohnson
parents:
diff changeset
61 dataset.metadata.base_name = fname[:-5]
65255beda972 Uploaded
jjohnson
parents:
diff changeset
62 break
65255beda972 Uploaded
jjohnson
parents:
diff changeset
63 self.regenerate_primary_file(dataset)
65255beda972 Uploaded
jjohnson
parents:
diff changeset
64
65255beda972 Uploaded
jjohnson
parents:
diff changeset
65