require 'scaffolder' module Scaffolder::Test class Annotation [:seqname,:start,:end,:strand,:phase,:feature,:attributes].each do |attribute| define_method(attribute) do |*arg| unless arg.first return @options[attribute] end @options[attribute] = arg.first return self end end def initialize(options = Hash.new) defaults = {:seqname => 'record', :start => 1, :end => 10, :strand => '+', :phase => 1, :feature => 'CDS'} @options = defaults.merge(options) end def initialize_copy(source) super @options = @options.dup end def to_gff3_record Bio::GFF::GFF3::Record.new( self.seqname, nil, self.feature, self.start, self.end, nil, self.strand, self.phase, self.attributes.to_a) end end end