Extracting matriarch thingy
This commit is contained in:
parent
47c3454848
commit
bf0c2523d5
2
matriarch/.gitignore
vendored
2
matriarch/.gitignore
vendored
@ -1,2 +0,0 @@
|
||||
Gemfile.lock
|
||||
.*env
|
@ -1,6 +0,0 @@
|
||||
source 'https://rubygems.org'
|
||||
|
||||
gem 'activesupport'
|
||||
gem 'puma'
|
||||
gem 'sinatra'
|
||||
gem 'sinatra-contrib', require: 'sinatra/contrib'
|
@ -1,5 +0,0 @@
|
||||
lib = File.expand_path('../lib', __FILE__)
|
||||
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
||||
|
||||
require 'matriarch'
|
||||
run Matriarch::App
|
@ -1,4 +0,0 @@
|
||||
module Matriarch
|
||||
autoload :App, 'matriarch/app'
|
||||
autoload :Config, 'matriarch/config'
|
||||
end
|
@ -1,19 +0,0 @@
|
||||
require 'matriarch'
|
||||
require 'json'
|
||||
require 'sinatra/base'
|
||||
require 'sinatra/json'
|
||||
|
||||
module Matriarch
|
||||
class App < Sinatra::Base
|
||||
get '/' do
|
||||
"oh hai\n"
|
||||
end
|
||||
|
||||
post '/matrix' do
|
||||
config = ::Matriarch::Config.new(JSON.parse(request.body.read))
|
||||
json data: config.expand
|
||||
end
|
||||
|
||||
run! if app_file == $PROGRAM_NAME
|
||||
end
|
||||
end
|
@ -1,189 +0,0 @@
|
||||
require 'active_support/core_ext/array/wrap'
|
||||
require 'active_support/core_ext/hash/keys'
|
||||
require 'active_support/core_ext/hash/slice'
|
||||
require 'active_support/core_ext/object/try'
|
||||
|
||||
module Matriarch
|
||||
class Config
|
||||
DEFAULT_LANG = 'ruby'.freeze
|
||||
|
||||
ENV_KEYS = [
|
||||
:compiler,
|
||||
:csharp,
|
||||
:d,
|
||||
:dart,
|
||||
:elixir,
|
||||
:env,
|
||||
:fsharp,
|
||||
:gemfile,
|
||||
:ghc,
|
||||
:go,
|
||||
:haxe,
|
||||
:jdk,
|
||||
:julia,
|
||||
:mono,
|
||||
:node_js,
|
||||
:otp_release,
|
||||
:perl,
|
||||
:perl6,
|
||||
:php,
|
||||
:python,
|
||||
:ruby,
|
||||
:rust,
|
||||
:rvm,
|
||||
:scala,
|
||||
:visualbasic,
|
||||
:xcode_scheme,
|
||||
:xcode_sdk
|
||||
].freeze
|
||||
|
||||
EXPANSION_KEYS_FEATURE = [:os].freeze
|
||||
|
||||
EXPANSION_KEYS_LANGUAGE = {
|
||||
'c' => [:compiler],
|
||||
'c++' => [:compiler],
|
||||
'clojure' => [:lein, :jdk],
|
||||
'cpp' => [:compiler],
|
||||
'csharp' => [:csharp, :mono],
|
||||
'd' => [:d],
|
||||
'dart' => [:dart],
|
||||
'elixir' => [:elixir, :otp_release],
|
||||
'erlang' => [:otp_release],
|
||||
'fsharp' => [:fsharp, :mono],
|
||||
'go' => [:go],
|
||||
'groovy' => [:jdk],
|
||||
'haskell' => [:ghc],
|
||||
'haxe' => [:haxe],
|
||||
'java' => [:jdk],
|
||||
'julia' => [:julia],
|
||||
'node_js' => [:node_js],
|
||||
'objective-c' => [:rvm, :gemfile, :xcode_sdk, :xcode_scheme],
|
||||
'perl' => [:perl],
|
||||
'perl6' => [:perl6],
|
||||
'php' => [:php],
|
||||
'python' => [:python],
|
||||
'ruby' => [:rvm, :gemfile, :jdk, :ruby],
|
||||
'rust' => [:rust],
|
||||
'scala' => [:scala, :jdk],
|
||||
'visualbasic' => [:visualbasic, :mono]
|
||||
}.freeze
|
||||
|
||||
EXPANSION_KEYS_UNIVERSAL = [:env, :branch].freeze
|
||||
|
||||
def self.matrix_keys_for(config, options = {})
|
||||
keys = matrix_keys(config, options)
|
||||
keys & config.keys.map(&:to_sym)
|
||||
end
|
||||
|
||||
def self.matrix_keys(config, options = {})
|
||||
lang = Array(config.symbolize_keys[:language]).first
|
||||
keys = ENV_KEYS
|
||||
keys &= EXPANSION_KEYS_LANGUAGE.fetch(lang, EXPANSION_KEYS_LANGUAGE[DEFAULT_LANG])
|
||||
keys << :os if options[:multi_os]
|
||||
keys += [:dist, :group] if options[:dist_group_expansion]
|
||||
keys | EXPANSION_KEYS_UNIVERSAL
|
||||
end
|
||||
|
||||
def initialize(config, options = {})
|
||||
@config = config.symbolize_keys
|
||||
@options = options
|
||||
end
|
||||
|
||||
def expand
|
||||
configs = expand_matrix
|
||||
configs = include_matrix_configs(exclude_matrix_configs(configs))
|
||||
configs = configs.map { |config| cleanup_config(merge_config(Hash[config])) }
|
||||
configs
|
||||
# configs.map { |config| Build::Config::OS.new(config, options).run }
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
attr_reader :config, :options
|
||||
|
||||
def allow_failure_configs
|
||||
(settings[:allow_failures] || []).select do |config|
|
||||
config = config.to_hash.symbolize_keys if config.respond_to?(:to_hash)
|
||||
end
|
||||
end
|
||||
|
||||
def fast_finish?
|
||||
settings[:fast_finish]
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def settings
|
||||
@settings ||= config[:matrix] || {}
|
||||
@settings = {} if @settings.is_a?(Array)
|
||||
@settings
|
||||
end
|
||||
|
||||
def expand_matrix
|
||||
rows = config.slice(*expand_keys).values.select { |value| value.is_a?(Array) }
|
||||
max_size = rows.max_by(&:size).try(:size) || 1
|
||||
|
||||
array = expand_keys.inject([]) do |result, key|
|
||||
values = Array.wrap(config[key])
|
||||
values += [values.last] * (max_size - values.size)
|
||||
result << values.map { |value| [key, value] }
|
||||
end
|
||||
|
||||
permutations(array).uniq
|
||||
end
|
||||
|
||||
# recursively builds up permutations of values in the rows of a nested array
|
||||
def permutations(base, result = [])
|
||||
base = base.dup
|
||||
base.empty? ? [result] : base.shift.map { |value| permutations(base, result + [value]) }.flatten(1)
|
||||
end
|
||||
|
||||
def expand_keys
|
||||
@expand_keys ||= config.keys.map(&:to_sym) & self.class.matrix_keys_for(config, options)
|
||||
end
|
||||
|
||||
def exclude_matrix_configs(configs)
|
||||
configs.reject { |config| exclude_config?(config) }
|
||||
end
|
||||
|
||||
def exclude_config?(config)
|
||||
exclude_configs = normalize_matrix_filter_configs(settings[:exclude] || [])
|
||||
config = config.map { |config| [config[0].to_s, *config[1..-1]] }.sort
|
||||
exclude_configs.any? do |excluded|
|
||||
excluded.all? { |matrix_key| config.include? matrix_key }
|
||||
end
|
||||
end
|
||||
|
||||
def include_matrix_configs(configs)
|
||||
include_configs = normalize_matrix_filter_configs(settings[:include] || [])
|
||||
if configs.flatten.empty? && settings.has_key?(:include)
|
||||
include_configs
|
||||
else
|
||||
configs + include_configs
|
||||
end
|
||||
end
|
||||
|
||||
def normalize_matrix_filter_configs(configs)
|
||||
configs = configs.select { |c| c.is_a?(Hash) }
|
||||
configs = configs.compact.map(&:stringify_keys)
|
||||
configs.map(&:to_a).map(&:sort)
|
||||
end
|
||||
|
||||
def merge_config(row)
|
||||
config.select { |key, value| include_key?(key) }.merge(row)
|
||||
end
|
||||
|
||||
def cleanup_config(config)
|
||||
config.delete(:matrix)
|
||||
config
|
||||
end
|
||||
|
||||
def include_key?(key)
|
||||
self.class.matrix_keys_for(config, options).include?(key.to_sym) || !known_env_key?(key.to_sym)
|
||||
end
|
||||
|
||||
def known_env_key?(key)
|
||||
(ENV_KEYS | EXPANSION_KEYS_FEATURE).include?(key)
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue
Block a user