Class: Origen::Generator
- Inherits:
-
Object
- Object
- Origen::Generator
- Includes:
- Comparator
- Defined in:
- lib/origen_testers/origen_ext/generator.rb,
lib/origen_testers/origen_ext/generator/flow.rb,
lib/origen_testers/origen_ext/generator/pattern.rb,
lib/origen_testers/origen_ext/generator/resources.rb
Defined Under Namespace
Classes: Flow, Pattern, Resources
Instance Method Summary collapse
Instance Method Details
#generate_program(file, options) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
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 |
# File 'lib/origen_testers/origen_ext/generator.rb', line 13 def generate_program(file, ) Origen.file_handler.resolve_files(file, ignore_with_prefix: '_', default_dir: "#{Origen.root}/program") do |path| Origen.file_handler.current_file = path j = Job.new(path, ) j.pattern = path j.run end yield if block_given? Origen.interface.write_files() unless [:quiet] || !Origen.interface.write? || [:skip_referenced_pattern_write] if [:referenced_pattern_list] file = "#{Origen.root}/list/#{[:referenced_pattern_list]}" else file = Origen.config.referenced_pattern_list end Origen.log.info "Referenced pattern list written to: #{Pathname.new(file).relative_path_from(Pathname.pwd)}" dir = Pathname.new(file).dirname FileUtils.mkdir_p(dir) unless dir.exist? File.open(file, 'w') do |f| pats = Origen.interface.all_pattern_references.map do |name, refs| refs[:main][:all] + refs[:main][:origen] end.flatten.uniq.sort unless pats.empty? f.puts '# Main patterns' pats.each { |p| f.puts p } f.puts end pats = Origen.interface.all_pattern_references.map do |name, refs| refs[:subroutine][:all] + refs[:subroutine][:origen] end.flatten.uniq.sort unless pats.empty? f.puts '# Subroutine patterns' pats.each { |p| f.puts p } end end ref_file = File.join(Origen.file_handler.reference_directory, Pathname.new(file).basename) check_for_changes(file, ref_file) end Origen.interface.on_program_completion() unless [:skip_on_program_completion] end |