Sha256: fd2c9f4c6c0a96d6c61d0df4a55410fbc6a74a0bb858f268852b70121749d1cd

Contents?: true

Size: 983 Bytes

Versions: 49

Compression:

Stored size: 983 Bytes

Contents

require 'tsort'

module Watir
  module Generator
    class Base::IDLSorter
      include TSort

      def initialize(interfaces)
        @interfaces = {}

        interfaces.each do |interface|
          @interfaces[interface.name] ||= []
          interface.inherits.each do |inherit|
            (@interfaces[inherit.name] ||= []) << interface.name
          end
        end
      end

      def print
        @visited = []
        sort.each { |node| print_node(node) }
      end

      def sort
        tsort.reverse
      end

      def tsort_each_node(&blk)
        @interfaces.each_key(&blk)
      end

      def tsort_each_child(node, &blk)
        @interfaces[node].each(&blk)
      end

      private

      def print_node(node, indent = 0)
        return if @visited.include?(node)
        @visited << node
        puts " " * indent + node
        tsort_each_child(node) { |child| print_node(child, indent + 2)}
      end

    end # IDLSorter
  end # Generator
end # Watir

Version data entries

49 entries across 49 versions & 2 rubygems

Version Path
watir-6.0.0.beta4 lib/watir/generator/base/idl_sorter.rb
watir-6.0.0.beta3 lib/watir/generator/base/idl_sorter.rb
watir-6.0.0.beta2 lib/watir/generator/base/idl_sorter.rb
watir-6.0.0.beta1 lib/watir/generator/base/idl_sorter.rb
watir-webdriver-0.9.3 lib/watir-webdriver/generator/base/idl_sorter.rb
watir-webdriver-0.9.2 lib/watir-webdriver/generator/base/idl_sorter.rb
watir-webdriver-0.9.1 lib/watir-webdriver/generator/base/idl_sorter.rb
watir-webdriver-0.9.0 lib/watir-webdriver/generator/base/idl_sorter.rb
watir-webdriver-0.8.0 lib/watir-webdriver/generator/base/idl_sorter.rb