Sha256: 2a883f294e8631eaad64bbf9f98351fc4b34562ffd12c647bde3ec66e53187a6
Contents?: true
Size: 1.96 KB
Versions: 1
Compression:
Stored size: 1.96 KB
Contents
# frozen_string_literal: true module Jekyll module Utils module Platforms extend self # Provides jruby? and mri? which respectively detect these two types of # tested Engines we support, in the future we might probably support the # other one that everyone used to talk about. { :jruby? => "jruby", :mri? => "ruby" }.each do |k, v| define_method k do ::RUBY_ENGINE == v end end # -- # Allows you to detect "real" Windows, or what we would consider # "real" Windows. That is, that we can pass the basic test and the # /proc/version returns nothing to us. # -- def vanilla_windows? RbConfig::CONFIG["host_os"] =~ %r!mswin|mingw|cygwin!i && \ !proc_version end # -- # XXX: Remove in 4.0 # -- alias_method :really_windows?, \ :vanilla_windows? # def bash_on_windows? RbConfig::CONFIG["host_os"] =~ %r!linux! && \ proc_version =~ %r!microsoft!i end # def windows? vanilla_windows? || bash_on_windows? end # def linux? RbConfig::CONFIG["host_os"] =~ %r!linux! && \ proc_version !~ %r!microsoft!i end # Provides windows?, linux?, osx?, unix? so that we can detect # platforms. This is mostly useful for `jekyll doctor` and for testing # where we kick off certain tests based on the platform. { :osx? => %r!darwin|mac os!, :unix? => %r!solaris|bsd! }.each do |k, v| define_method k do !!( RbConfig::CONFIG["host_os"] =~ v ) end end # private def proc_version @proc_version ||= begin Pathutil.new("/proc/version").read rescue Errno::ENOENT, Errno::EACCES nil end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
ngage-0.0.0 | lib/ngage/jekyll/utils/platforms.rb |