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