require 'pathname' # Hanami - The web, with simplicity # # @since 0.1.0 module Hanami require 'hanami/utils/version' require 'hanami/utils/file_list' # Ruby core extentions and Hanami utilities # # @since 0.1.0 module Utils # @since 0.3.1 # @api private HANAMI_JRUBY = 'java'.freeze # @since 0.3.1 # @api private HANAMI_RUBINIUS = 'rbx'.freeze # Checks if the current VM is JRuby # # @return [TrueClass,FalseClass] return if the VM is JRuby or not # # @since 0.3.1 # @api private def self.jruby? RUBY_PLATFORM == HANAMI_JRUBY end # Checks if the current VM is Rubinius # # @return [TrueClass,FalseClass] return if the VM is Rubinius or not # # @since 0.3.1 # @api private def self.rubinius? RUBY_ENGINE == HANAMI_RUBINIUS end # Recursively require Ruby files under the given directory. # # If the directory is relative, it implies it's the path from current directory. # If the directory is absolute, it uses as it is. # # It respects file separator of the current operating system. # A pattern like "path/to/files" will work both on *NIX and Windows machines. # # @param directory [String, Pathname] the directory # # @since 0.9.0 def self.require!(directory) for_each_file_in(directory) { |file| require_relative(file) } end # Recursively reload Ruby files under the given directory. # # If the directory is relative, it implies it's the path from current directory. # If the directory is absolute, it uses as it is. # # It respects file separator of the current operating system. # A pattern like "path/to/files" will work both on *NIX and Windows machines. # # @param directory [String, Pathname] the directory # # @since 1.0.0 # @api private def self.reload!(directory) for_each_file_in(directory) { |file| load(file) } end # Recursively scans through the given directory and yields the given block # for each Ruby source file. # # If the directory is relative, it implies it's the path from current directory. # If the directory is absolute, it uses as it is. # # It respects file separator of the current operating system. # A pattern like "path/to/files" will work both on *NIX and Windows machines. # # @param directory [String, Pathname] the directory # @param blk [Proc] the block to yield # # @since 1.0.0 # @api private def self.for_each_file_in(directory, &blk) directory = directory.to_s.gsub(%r{(\/|\\)}, File::SEPARATOR) directory = Pathname.new(Dir.pwd).join(directory).to_s directory = File.join(directory, '**', '*.rb') unless directory =~ /(\*\*)/ FileList[directory].each(&blk) end end end