scout-gear 6.0.0 → 7.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (85) hide show
  1. checksums.yaml +4 -4
  2. data/.vimproject +465 -432
  3. data/VERSION +1 -1
  4. data/bin/scout +5 -1
  5. data/lib/rbbt-scout.rb +5 -0
  6. data/lib/scout/concurrent_stream.rb +6 -2
  7. data/lib/scout/config.rb +168 -0
  8. data/lib/scout/exceptions.rb +9 -0
  9. data/lib/scout/indiferent_hash/options.rb +1 -0
  10. data/lib/scout/indiferent_hash.rb +4 -2
  11. data/lib/scout/log/color.rb +31 -2
  12. data/lib/scout/log/progress/report.rb +1 -0
  13. data/lib/scout/log/progress/util.rb +3 -1
  14. data/lib/scout/log/progress.rb +7 -3
  15. data/lib/scout/log.rb +8 -3
  16. data/lib/scout/misc/digest.rb +1 -3
  17. data/lib/scout/misc/monitor.rb +3 -0
  18. data/lib/scout/misc/system.rb +15 -0
  19. data/lib/scout/misc.rb +1 -0
  20. data/lib/scout/named_array.rb +68 -0
  21. data/lib/scout/open/stream.rb +58 -26
  22. data/lib/scout/path/find.rb +27 -3
  23. data/lib/scout/path/util.rb +7 -4
  24. data/lib/scout/persist/serialize.rb +7 -14
  25. data/lib/scout/persist.rb +21 -1
  26. data/lib/scout/resource/produce.rb +7 -94
  27. data/lib/scout/resource/software.rb +176 -0
  28. data/lib/scout/tsv/dumper.rb +107 -0
  29. data/lib/scout/tsv/index.rb +49 -0
  30. data/lib/scout/tsv/parser.rb +317 -0
  31. data/lib/scout/tsv/path.rb +13 -0
  32. data/lib/scout/tsv/persist/adapter.rb +348 -0
  33. data/lib/scout/tsv/persist/tokyocabinet.rb +113 -0
  34. data/lib/scout/tsv/persist.rb +15 -0
  35. data/lib/scout/tsv/traverse.rb +48 -0
  36. data/lib/scout/tsv/util.rb +24 -0
  37. data/lib/scout/tsv.rb +27 -0
  38. data/lib/scout/work_queue/worker.rb +16 -11
  39. data/lib/scout/work_queue.rb +63 -21
  40. data/lib/scout/workflow/definition.rb +93 -4
  41. data/lib/scout/workflow/step/config.rb +18 -0
  42. data/lib/scout/workflow/step/dependencies.rb +40 -0
  43. data/lib/scout/workflow/step/file.rb +15 -0
  44. data/lib/scout/workflow/step/info.rb +33 -6
  45. data/lib/scout/workflow/step/provenance.rb +148 -0
  46. data/lib/scout/workflow/step.rb +70 -20
  47. data/lib/scout/workflow/task.rb +5 -4
  48. data/lib/scout/workflow/usage.rb +1 -1
  49. data/lib/scout/workflow.rb +11 -3
  50. data/lib/scout-gear.rb +1 -0
  51. data/lib/scout.rb +1 -0
  52. data/scout-gear.gemspec +38 -3
  53. data/scout_commands/find +1 -1
  54. data/scout_commands/workflow/task +16 -10
  55. data/share/software/install_helpers +523 -0
  56. data/test/scout/log/test_progress.rb +0 -2
  57. data/test/scout/misc/test_system.rb +21 -0
  58. data/test/scout/open/test_stream.rb +160 -1
  59. data/test/scout/path/test_find.rb +14 -7
  60. data/test/scout/resource/test_software.rb +24 -0
  61. data/test/scout/test_config.rb +66 -0
  62. data/test/scout/test_meta_extension.rb +10 -0
  63. data/test/scout/test_named_array.rb +19 -0
  64. data/test/scout/test_persist.rb +35 -0
  65. data/test/scout/test_semaphore.rb +1 -1
  66. data/test/scout/test_tmpfile.rb +2 -2
  67. data/test/scout/test_tsv.rb +74 -0
  68. data/test/scout/test_work_queue.rb +63 -8
  69. data/test/scout/tsv/persist/test_adapter.rb +34 -0
  70. data/test/scout/tsv/persist/test_tokyocabinet.rb +92 -0
  71. data/test/scout/tsv/test_dumper.rb +44 -0
  72. data/test/scout/tsv/test_index.rb +64 -0
  73. data/test/scout/tsv/test_parser.rb +173 -0
  74. data/test/scout/tsv/test_persist.rb +36 -0
  75. data/test/scout/tsv/test_traverse.rb +9 -0
  76. data/test/scout/tsv/test_util.rb +0 -0
  77. data/test/scout/work_queue/test_worker.rb +49 -1
  78. data/test/scout/workflow/step/test_dependencies.rb +25 -0
  79. data/test/scout/workflow/step/test_info.rb +15 -17
  80. data/test/scout/workflow/step/test_load.rb +16 -18
  81. data/test/scout/workflow/step/test_provenance.rb +25 -0
  82. data/test/scout/workflow/test_step.rb +206 -10
  83. data/test/scout/workflow/test_task.rb +0 -3
  84. data/test/test_helper.rb +6 -0
  85. metadata +37 -2
data/.vimproject CHANGED
@@ -18,6 +18,7 @@ scout-gear=/$PWD filter="*.rb *.yaml" {
18
18
  lib=lib {
19
19
  scout-gear.rb
20
20
  workflow-scout.rb
21
+ rbbt-scout.rb
21
22
  scout.rb
22
23
  scout=scout{
23
24
  meta_extension.rb
@@ -30,7 +31,9 @@ scout-gear=/$PWD filter="*.rb *.yaml" {
30
31
  digest.rb
31
32
  filesystem.rb
32
33
  monitor.rb
34
+ system.rb
33
35
  }
36
+ named_array.rb
34
37
  indiferent_hash.rb
35
38
  indiferent_hash=indiferent_hash{
36
39
  case_insensitive.rb
@@ -77,10 +80,12 @@ scout-gear=/$PWD filter="*.rb *.yaml" {
77
80
  produce=produce{
78
81
  rake.rb
79
82
  }
83
+ software.rb
80
84
  scout.rb
81
85
  util.rb
82
86
  path.rb
83
87
  }
88
+ config.rb
84
89
  persist.rb
85
90
  persist=persist{
86
91
  serialize.rb
@@ -94,6 +99,10 @@ scout-gear=/$PWD filter="*.rb *.yaml" {
94
99
  step=step{
95
100
  info.rb
96
101
  load.rb
102
+ file.rb
103
+ config.rb
104
+ dependencies.rb
105
+ provenance.rb
97
106
  }
98
107
  task.rb
99
108
  task=task{
@@ -109,6 +118,20 @@ scout-gear=/$PWD filter="*.rb *.yaml" {
109
118
  socket.rb
110
119
  worker.rb
111
120
  }
121
+ tsv.rb
122
+ tsv=tsv{
123
+ parser.rb
124
+ dumper.rb
125
+ persist.rb
126
+ index.rb
127
+ persist=persist{
128
+ adapter.rb
129
+ tokyocabinet.rb
130
+ }
131
+ traverse.rb
132
+ util.rb
133
+ path.rb
134
+ }
112
135
  }
113
136
  }
114
137
  test=test {
@@ -122,6 +145,13 @@ scout-gear=/$PWD filter="*.rb *.yaml" {
122
145
  test_tmpfile.rb
123
146
  }
124
147
  }
148
+ share=share{
149
+ software=software{
150
+ install_helpers
151
+ }
152
+ }
153
+
154
+
125
155
 
126
156
  modules=modules{
127
157
  rbbt-util=rbbt-util filter="*.rb *.rake Rakefile *.rdoc *.R *.sh *.js *.haml *.sass *.txt *.conf LICENSE" {
@@ -241,477 +271,480 @@ scout-gear=/$PWD filter="*.rb *.yaml" {
241
271
  migrate.rb
242
272
  }
243
273
 
244
- monitor.rb
274
+ monitor.rb
245
275
 
246
- workflow.rb
247
- workflow=workflow{
248
- annotate.rb
276
+ workflow.rb
277
+ workflow=workflow{
278
+ annotate.rb
249
279
 
250
- definition.rb
251
- dependencies.rb
280
+ definition.rb
281
+ dependencies.rb
252
282
 
253
- accessor.rb
283
+ accessor.rb
254
284
 
255
- task.rb
285
+ task.rb
256
286
 
257
- step.rb
258
- step=step{
259
- accessor.rb
260
- dependencies.rb
261
- info.rb
262
- prepare.rb
263
- run.rb
264
- save_load_inputs.rb
265
- status.rb
266
- }
287
+ step.rb
288
+ step=step{
289
+ accessor.rb
290
+ dependencies.rb
291
+ info.rb
292
+ prepare.rb
293
+ run.rb
294
+ save_load_inputs.rb
295
+ status.rb
296
+ }
267
297
 
268
- examples.rb
269
- doc.rb
270
- usage.rb
298
+ examples.rb
299
+ doc.rb
300
+ usage.rb
271
301
 
272
- soap.rb
302
+ soap.rb
273
303
 
274
- util=util{
275
- archive.rb
276
- provenance.rb
277
- orchestrator.rb
278
- trace.rb
279
- data.rb
280
- }
304
+ util=util{
305
+ archive.rb
306
+ provenance.rb
307
+ orchestrator.rb
308
+ trace.rb
309
+ data.rb
310
+ }
281
311
 
282
- remote_workflow.rb
283
- remote_workflow=remote_workflow{
284
- driver.rb
285
- driver=driver{
286
- rest.rb
287
- ssh.rb
288
- }
312
+ remote_workflow.rb
313
+ remote_workflow=remote_workflow{
314
+ driver.rb
315
+ driver=driver{
316
+ rest.rb
317
+ ssh.rb
318
+ }
289
319
 
290
- remote_step.rb
291
- remote_step=remote_step{
292
- rest.rb
293
- ssh.rb
294
- }
295
- }
320
+ remote_step.rb
321
+ remote_step=remote_step{
322
+ rest.rb
323
+ ssh.rb
324
+ }
325
+ }
296
326
 
297
- integration=integration{
298
- cromwell.rb
299
- nextflow.rb
300
- ansible.rb
301
- ansible=ansible{
302
- workflow.rb
327
+ integration=integration{
328
+ cromwell.rb
329
+ nextflow.rb
330
+ ansible.rb
331
+ ansible=ansible{
332
+ workflow.rb
333
+ }
334
+ }
303
335
  }
304
- }
305
- }
306
-
307
- hpc.rb
308
- hpc=hpc{
309
- old=old{
310
- slurm.rb
311
- }
312
- orchestrate.old.rb
313
-
314
- batch.rb
315
- slurm.rb
316
- lsf.rb
317
-
318
- orchestrate.rb
319
- orchestrate=orchestrate{
320
- rules.rb
321
- chains.rb
322
- batches.rb
323
- }
324
- trace.rb
325
- }
326
336
 
327
- tsv.rb
328
- tsv=tsv{
329
- parser.rb
330
- dumper.rb
337
+ hpc.rb
338
+ hpc=hpc{
339
+ old=old{
340
+ slurm.rb
341
+ }
342
+ orchestrate.old.rb
331
343
 
332
- matrix.rb
344
+ batch.rb
345
+ slurm.rb
346
+ lsf.rb
333
347
 
334
- accessor.rb
335
- util.rb
336
- marshal.rb
337
- serializers.rb
338
- manipulate.rb
339
- index.rb
340
- stream.rb
341
- attach.rb
342
- attach=attach{
343
- util.rb
344
- }
345
- melt.rb
346
- excel.rb
347
- csv.rb
348
- filter.rb
349
- field_index.rb
350
- change_id.rb
351
- parallel.rb
352
- parallel=parallel{
353
- traverse.rb
354
- through.rb
355
- }
356
- }
348
+ orchestrate.rb
349
+ orchestrate=orchestrate{
350
+ rules.rb
351
+ chains.rb
352
+ batches.rb
353
+ }
354
+ trace.rb
355
+ }
357
356
 
358
- packed_index.rb
359
- fix_width_table.rb
357
+ tsv.rb
358
+ tsv=tsv{
359
+ parser.rb
360
+ dumper.rb
360
361
 
361
- persist.rb
362
- persist=persist{
363
- refactor.rb
364
- tsv.rb
365
- tsv=tsv{
366
- adapter.rb
362
+ matrix.rb
367
363
 
368
- sharder.rb
369
- tokyocabinet.rb
370
- tokyocabinet=tokyocabinet{
364
+ accessor.rb
365
+ util.rb
371
366
  marshal.rb
367
+ serializers.rb
368
+ manipulate.rb
369
+ index.rb
370
+ stream.rb
371
+ attach.rb
372
+ attach=attach{
373
+ util.rb
374
+ }
375
+ melt.rb
376
+ excel.rb
377
+ csv.rb
378
+ filter.rb
379
+ field_index.rb
380
+ change_id.rb
381
+ parallel.rb
382
+ parallel=parallel{
383
+ traverse.rb
384
+ through.rb
385
+ }
372
386
  }
373
- fix_width_table.rb
387
+
374
388
  packed_index.rb
375
- kyotocabinet.rb
376
- lmdb.rb
377
- cdb.rb
378
- leveldb.rb
379
- }
380
- }
389
+ fix_width_table.rb
381
390
 
382
- resource.rb
383
- resource=resource{
384
- path.rb
385
- util.rb
386
- with_key.rb
387
- rake.rb
388
- }
391
+ persist.rb
392
+ persist=persist{
393
+ refactor.rb
394
+ tsv.rb
395
+ tsv=tsv{
396
+ adapter.rb
397
+
398
+ sharder.rb
399
+ tokyocabinet.rb
400
+ tokyocabinet=tokyocabinet{
401
+ marshal.rb
402
+ }
403
+ fix_width_table.rb
404
+ packed_index.rb
405
+ kyotocabinet.rb
406
+ lmdb.rb
407
+ cdb.rb
408
+ leveldb.rb
409
+ }
410
+ }
389
411
 
390
- annotations.rb
391
- annotations=annotations{
392
- util.rb
393
- annotated_array.rb
394
- }
412
+ resource.rb
413
+ resource=resource{
414
+ path.rb
415
+ path=path{
416
+ refactor.rb
417
+ }
418
+ util.rb
419
+ with_key.rb
420
+ rake.rb
421
+ }
395
422
 
396
- entity.rb
397
- entity=entity{
398
- identifiers.rb
399
- }
423
+ annotations.rb
424
+ annotations=annotations{
425
+ util.rb
426
+ annotated_array.rb
427
+ }
400
428
 
401
- association.rb
402
- association=association{
403
- util.rb
404
- database.rb
405
- open.rb
406
- index.rb
407
- item.rb
408
- }
429
+ entity.rb
430
+ entity=entity{
431
+ identifiers.rb
432
+ }
409
433
 
410
- knowledge_base.rb
411
- knowledge_base=knowledge_base{
412
- enrichment.rb
413
- entity.rb
414
- query.rb
415
- registry.rb
416
- syndicate.rb
417
- traverse.rb
418
- }
419
- }
420
- }
421
- test=test {
422
- test_helper.rb
423
- data=data filter="*"{
424
- Test.xls
425
- dose_response
426
- dose_response2
427
- dose_response3
428
- example.pdf
429
- gene_ages
430
- identifiers
431
- test.tsv
432
- }
433
- rbbt=rbbt{
434
- test_annotations.rb
435
- test_association.rb
436
- test_entity.rb
437
- test_fix_width_table.rb
438
- test_knowledge_base.rb
439
- test_monitor.rb
440
- test_packed_index.rb
441
- test_persist.rb
442
- test_resource.rb
443
- test_tsv.rb
444
- test_workflow.rb
445
- resource=resource{
446
- test_path.rb
434
+ association.rb
435
+ association=association{
436
+ util.rb
437
+ database.rb
438
+ open.rb
439
+ index.rb
440
+ item.rb
441
+ }
442
+
443
+ knowledge_base.rb
444
+ knowledge_base=knowledge_base{
445
+ enrichment.rb
446
+ entity.rb
447
+ query.rb
448
+ registry.rb
449
+ syndicate.rb
450
+ traverse.rb
451
+ }
447
452
  }
448
- workflow=workflow{
449
- _test_soap.rb
450
- test_doc.rb
451
- test_step.rb
452
- test_task.rb
453
453
  }
454
- association=association{
455
- test_database.rb
456
- test_index.rb
457
- test_item.rb
458
- test_open.rb
459
- test_util.rb
460
- }
461
- knowledge_base=knowledge_base{
462
- test_enrichment.rb
463
- test_query.rb
464
- test_registry.rb
454
+ test=test {
455
+ test_helper.rb
456
+ data=data filter="*"{
457
+ Test.xls
458
+ dose_response
459
+ dose_response2
460
+ dose_response3
461
+ example.pdf
462
+ gene_ages
463
+ identifiers
464
+ test.tsv
465
465
  }
466
- persist=persist{
467
- tsv=tsv{
468
- test_cdb.rb
469
- test_kyotocabinet.rb
470
- test_leveldb.rb
471
- test_lmdb.rb
472
- test_sharder.rb
473
- test_tokyocabinet.rb
474
- }
475
- test_tsv.rb
476
- }
477
- tsv=tsv{
478
- test_accessor.rb
479
- test_attach.rb
480
- test_change_id.rb
481
- test_csv.rb
482
- test_excel.rb
483
- test_field_index.rb
484
- test_filter.rb
485
- test_index.rb
486
- test_manipulate.rb
487
- test_matrix.rb
488
- test_parallel.rb
489
- test_parser.rb
490
- test_stream.rb
491
- test_util.rb
492
- parallel=parallel{
493
- test_through.rb
494
- test_traverse.rb
466
+ rbbt=rbbt{
467
+ test_annotations.rb
468
+ test_association.rb
469
+ test_entity.rb
470
+ test_fix_width_table.rb
471
+ test_knowledge_base.rb
472
+ test_monitor.rb
473
+ test_packed_index.rb
474
+ test_persist.rb
475
+ test_resource.rb
476
+ test_tsv.rb
477
+ test_workflow.rb
478
+ resource=resource{
479
+ test_path.rb
480
+ }
481
+ workflow=workflow{
482
+ _test_soap.rb
483
+ test_doc.rb
484
+ test_step.rb
485
+ test_task.rb
486
+ }
487
+ association=association{
488
+ test_database.rb
489
+ test_index.rb
490
+ test_item.rb
491
+ test_open.rb
492
+ test_util.rb
493
+ }
494
+ knowledge_base=knowledge_base{
495
+ test_enrichment.rb
496
+ test_query.rb
497
+ test_registry.rb
498
+ }
499
+ persist=persist{
500
+ tsv=tsv{
501
+ test_cdb.rb
502
+ test_kyotocabinet.rb
503
+ test_leveldb.rb
504
+ test_lmdb.rb
505
+ test_sharder.rb
506
+ test_tokyocabinet.rb
507
+ }
508
+ test_tsv.rb
509
+ }
510
+ tsv=tsv{
511
+ test_accessor.rb
512
+ test_attach.rb
513
+ test_change_id.rb
514
+ test_csv.rb
515
+ test_excel.rb
516
+ test_field_index.rb
517
+ test_filter.rb
518
+ test_index.rb
519
+ test_manipulate.rb
520
+ test_matrix.rb
521
+ test_parallel.rb
522
+ test_parser.rb
523
+ test_stream.rb
524
+ test_util.rb
525
+ parallel=parallel{
526
+ test_through.rb
527
+ test_traverse.rb
528
+ }
529
+ }
530
+ entity=entity{
531
+ test_identifiers.rb
532
+ }
533
+ util=util{
534
+ test_R.rb
535
+ test_chain_methods.rb
536
+ test_cmd.rb
537
+ test_colorize.rb
538
+ test_concurrency.rb
539
+ test_config.rb
540
+ test_excel2tsv.rb
541
+ test_filecache.rb
542
+ test_log.rb
543
+ test_misc.rb
544
+ test_open.rb
545
+ test_python.rb
546
+ test_semaphore.rb
547
+ test_simpleDSL.rb
548
+ test_simpleopt.rb
549
+ test_tmpfile.rb
550
+ R=R{
551
+ test_eval.rb
552
+ test_model.rb
553
+ test_plot.rb
554
+ }
555
+ misc=misc{
556
+ test_bgzf.rb
557
+ test_format.rb
558
+ test_lock.rb
559
+ test_multipart_payload.rb
560
+ test_omics.rb
561
+ test_pipes.rb
562
+ }
563
+ simpleopt=simpleopt{
564
+ test_get.rb
565
+ test_parse.rb
566
+ test_setup.rb
567
+ }
568
+ concurrency=concurrency{
569
+ test_processes.rb
570
+ test_threads.rb
571
+ }
572
+ }
495
573
  }
496
574
  }
497
- entity=entity{
498
- test_identifiers.rb
575
+ python=python filter="*"{
576
+ rbbt.py
577
+ }
578
+ integration_test=integration_test{
579
+ test_bed.rb
580
+ test_helper.rb
581
+ test_namespaces.rb
582
+ test_workflow.rb
583
+ }
584
+ etc=etc filter="*"{
585
+ app.d=app.d{
586
+ init.rb
587
+
588
+ base.rb
589
+
590
+ requires.rb
591
+ entities.rb
592
+ finder.rb
593
+ foundation.rb
594
+ grid_system.rb
595
+ knowledge_bases.rb
596
+ resources.rb
597
+ workflows.rb
598
+ semaphores.rb
599
+ remote_workflow_tasks.rb
600
+ }
499
601
  }
500
- util=util{
501
- test_R.rb
502
- test_chain_methods.rb
503
- test_cmd.rb
504
- test_colorize.rb
505
- test_concurrency.rb
506
- test_config.rb
507
- test_excel2tsv.rb
508
- test_filecache.rb
509
- test_log.rb
510
- test_misc.rb
511
- test_open.rb
512
- test_python.rb
513
- test_semaphore.rb
514
- test_simpleDSL.rb
515
- test_simpleopt.rb
516
- test_tmpfile.rb
517
- R=R{
518
- test_eval.rb
519
- test_model.rb
520
- test_plot.rb
602
+ share=share{
603
+ config.ru
604
+ workflow_config.ru
605
+ unicorn.rb
606
+ color=color filter="*"{
607
+ diverging_colors.hex
608
+ color_names
521
609
  }
522
- misc=misc{
523
- test_bgzf.rb
524
- test_format.rb
525
- test_lock.rb
526
- test_multipart_payload.rb
527
- test_omics.rb
528
- test_pipes.rb
610
+ rbbt_commands=rbbt_commands filter="*"{
611
+ alias
612
+ ansible
613
+ check_bgzf
614
+ cmd
615
+ color
616
+ log
617
+ migrate
618
+ migrate_job
619
+ purge_job
620
+ rsync
621
+ watch
622
+ system=system{
623
+ clean
624
+ deleted_files
625
+ optimize
626
+ purge
627
+ report
628
+ status
629
+ }
630
+ conf=conf{
631
+ web_user=web_user{
632
+ add
633
+ list
634
+ remove
635
+ }
636
+ }
637
+ resource=resource{
638
+ exists
639
+ find
640
+ glob
641
+ get
642
+ produce
643
+ read
644
+ }
645
+ workflow=workflow{
646
+ archive
647
+ archive_all
648
+ cmd
649
+ example
650
+ forget_deps
651
+ info
652
+ write_info
653
+ init
654
+ install
655
+ jobs
656
+ knowledge_base
657
+ list
658
+ monitor
659
+ prov
660
+ server
661
+ task
662
+ trace
663
+ remote=remote{
664
+ add
665
+ list
666
+ remove
667
+ }
668
+ }
669
+ hpc=hpc{
670
+ task
671
+ orchestrate
672
+ tail
673
+ list
674
+ clean
675
+ }
676
+ app=app{
677
+ install
678
+ start
679
+ template
680
+ }
681
+ association=association{
682
+ subset
683
+ }
684
+ tsv=tsv{
685
+ assemble_pdf_table
686
+ attach
687
+ change_id
688
+ collapse
689
+ get
690
+ head
691
+ info
692
+ json
693
+ keys
694
+ query
695
+ read
696
+ read_excel
697
+ slice
698
+ sort
699
+ subset
700
+ select
701
+ transpose
702
+ uncollapse
703
+ unzip
704
+ values
705
+ write_excel
706
+ zip
707
+ view
708
+ }
709
+ stat=stat{
710
+ abs
711
+ boxplot
712
+ compare_lists
713
+ density
714
+ heatmap
715
+ log
716
+ pvalue.qqplot
717
+ }
718
+ study=study{
719
+ maf2study
720
+ task
721
+ }
722
+ file_server=file_server{
723
+ add
724
+ list
725
+ remove
726
+ }
727
+ benchmark=benchmark{
728
+ pthrough
729
+ throughput
730
+ tsv
731
+ }
529
732
  }
530
- simpleopt=simpleopt{
531
- test_get.rb
532
- test_parse.rb
533
- test_setup.rb
733
+ Rlib=Rlib{
734
+ plot.R
735
+ svg.R
736
+ util.R
534
737
  }
535
- concurrency=concurrency{
536
- test_processes.rb
537
- test_threads.rb
738
+ software=install/software filter="*"{
739
+ zran=zran{
740
+ zran.c
741
+ }
742
+ lib=lib{
743
+ install_helpers
538
744
  }
539
- }
540
- }
541
- }
542
- python=python filter="*"{
543
- rbbt.py
544
- }
545
- integration_test=integration_test{
546
- test_bed.rb
547
- test_helper.rb
548
- test_namespaces.rb
549
- test_workflow.rb
550
- }
551
- etc=etc filter="*"{
552
- app.d=app.d{
553
- init.rb
554
-
555
- base.rb
556
-
557
- requires.rb
558
- entities.rb
559
- finder.rb
560
- foundation.rb
561
- grid_system.rb
562
- knowledge_bases.rb
563
- resources.rb
564
- workflows.rb
565
- semaphores.rb
566
- remote_workflow_tasks.rb
567
- }
568
- }
569
- share=share{
570
- config.ru
571
- workflow_config.ru
572
- unicorn.rb
573
- color=color filter="*"{
574
- diverging_colors.hex
575
- color_names
576
- }
577
- rbbt_commands=rbbt_commands filter="*"{
578
- alias
579
- ansible
580
- check_bgzf
581
- cmd
582
- color
583
- log
584
- migrate
585
- migrate_job
586
- purge_job
587
- rsync
588
- watch
589
- system=system{
590
- clean
591
- deleted_files
592
- optimize
593
- purge
594
- report
595
- status
596
- }
597
- conf=conf{
598
- web_user=web_user{
599
- add
600
- list
601
- remove
602
- }
603
- }
604
- resource=resource{
605
- exists
606
- find
607
- glob
608
- get
609
- produce
610
- read
611
- }
612
- workflow=workflow{
613
- archive
614
- archive_all
615
- cmd
616
- example
617
- forget_deps
618
- info
619
- write_info
620
- init
621
- install
622
- jobs
623
- knowledge_base
624
- list
625
- monitor
626
- prov
627
- server
628
- task
629
- trace
630
- remote=remote{
631
- add
632
- list
633
- remove
634
745
  }
635
746
  }
636
- hpc=hpc{
637
- task
638
- orchestrate
639
- tail
640
- list
641
- clean
642
- }
643
- app=app{
644
- install
645
- start
646
- template
647
- }
648
- association=association{
649
- subset
650
- }
651
- tsv=tsv{
652
- assemble_pdf_table
653
- attach
654
- change_id
655
- collapse
656
- get
657
- head
658
- info
659
- json
660
- keys
661
- query
662
- read
663
- read_excel
664
- slice
665
- sort
666
- subset
667
- select
668
- transpose
669
- uncollapse
670
- unzip
671
- values
672
- write_excel
673
- zip
674
- view
675
- }
676
- stat=stat{
677
- abs
678
- boxplot
679
- compare_lists
680
- density
681
- heatmap
682
- log
683
- pvalue.qqplot
684
- }
685
- study=study{
686
- maf2study
687
- task
688
- }
689
- file_server=file_server{
690
- add
691
- list
692
- remove
693
- }
694
- benchmark=benchmark{
695
- pthrough
696
- throughput
697
- tsv
698
- }
699
- }
700
- Rlib=Rlib{
701
- plot.R
702
- svg.R
703
- util.R
704
747
  }
705
- software=install/software filter="*"{
706
- zran=zran{
707
- zran.c
708
- }
709
- lib=lib{
710
- install_helpers
711
- }
712
- }
713
- }
714
- }
715
748
 
716
749
  }
717
750
  }