diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2015-06-22 10:04:00 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2015-06-22 10:04:00 +0900 |
| commit | c8229dbd19da9a3e92d69e8d6ecc820aa2b18d53 (patch) | |
| tree | 0750d854f7f8509e18c61d6caa989d75e8d93605 /tasks/mrbgem_spec.rake | |
| parent | 7cf94bac100931cd80ac0b851d3de298e351b5b9 (diff) | |
| parent | 078d24d4d3f7b5aac436fb70e341e1a7668fdbbb (diff) | |
| download | mruby-c8229dbd19da9a3e92d69e8d6ecc820aa2b18d53.tar.gz mruby-c8229dbd19da9a3e92d69e8d6ecc820aa2b18d53.zip | |
Merge pull request #2846 from take-cheeze/mgem_mrbgem
Add :mgem gem loading.
Diffstat (limited to 'tasks/mrbgem_spec.rake')
| -rw-r--r-- | tasks/mrbgem_spec.rake | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/tasks/mrbgem_spec.rake b/tasks/mrbgem_spec.rake index e6e17e182..e22a39e19 100644 --- a/tasks/mrbgem_spec.rake +++ b/tasks/mrbgem_spec.rake @@ -304,7 +304,14 @@ module MRuby default_gems = [] each do |g| g.dependencies.each do |dep| - default_gems << dep if dep[:default] and not gem_table.key? dep[:gem] + unless gem_table.key? dep[:gem] + if dep[:default]; default_gems << dep + elsif File.exist? "#{root}/mrbgems/#{dep[:gem]}" # check core + default_gems << { :gem => dep[:gem], :default => { :core => dep[:gem] } } + else # fallback to mgem-list + default_gems << { :gem => dep[:gem], :default => { :mgem => dep[:gem] } } + end + end end end @@ -316,7 +323,11 @@ module MRuby spec.setup spec.dependencies.each do |dep| - default_gems << dep if dep[:default] and not gem_table.key? dep[:gem] + unless gem_table.key? dep[:gem] + if dep[:default]; default_gems << dep + else default_gems << { :gem => dep[:gem], :default => { :mgem => dep[:gem] } } + end + end end gem_table[spec.name] = spec end |
