stibium-bundled 0.0.3 → 0.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +46 -1
- data/lib/stibium/bundled.rb +18 -9
- data/lib/stibium/bundled/bundle.rb +16 -18
- data/lib/stibium/bundled/bundle/config.rb +7 -12
- data/lib/stibium/bundled/bundle/config/reader.rb +52 -0
- data/lib/stibium/bundled/bundle/directory.rb +5 -2
- data/lib/stibium/bundled/version.rb +18 -2
- data/lib/stibium/bundled/version.yml +3 -3
- metadata +6 -18
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 540a8ad588f6dbeb56f350aa54908bd240c2ec1f321d3885bfa1e5884cf45491
|
4
|
+
data.tar.gz: edfeef841ad795136cf3a6c41ea711f00f6029d160d46fb63197daed1cfb36e3
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c7839c5a74b6e12312fcf17729d3cf315e9242898d718c59f6501dae93bc34fd1da9cc8b1afe9ec1add479d4bd84115121931ead5a630c18caf54a99cac2d1f6
|
7
|
+
data.tar.gz: f27014af349f61a57484ed1f4d1d4fb1083c9ef84a0950b7e017f01d0ff82db75c547be623a71e2852fe9d604cc2c538e15d6a1a34ea29a6e5326bc3bada52f3
|
data/README.md
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
# ``stibium-bundled`` [][rubygems:stibium-bundled]
|
1
|
+
# ``stibium-bundled`` [][rubygems:stibium-bundled] [](https://codeclimate.com/github/SwagDevOps/stibium-bundled/maintainability)
|
2
2
|
|
3
3
|
This gem is intended to mimic Bundler's behavior and conform to [bundler configuration options][bundler:config].
|
4
4
|
|
@@ -62,6 +62,49 @@ module AwesomeGem
|
|
62
62
|
end
|
63
63
|
```
|
64
64
|
|
65
|
+
if ``stibium-bundled`` is not system wide installed, it can be necessary to
|
66
|
+
locate it:
|
67
|
+
|
68
|
+
```ruby
|
69
|
+
# file: lib/awesome_gem.rb
|
70
|
+
|
71
|
+
module AwesomeGem
|
72
|
+
Pathname.new("#{__dir__}/..").expand_path.tap do |basedir|
|
73
|
+
begin
|
74
|
+
require 'stibium/bundled'
|
75
|
+
rescue LoadError
|
76
|
+
basedir.join('{**/,}bundle', RUBY_ENGINE, RUBY_VERSION, '{bundler,}/gems/*/stibium-bundled.gemspec').tap do |s|
|
77
|
+
Pathname.glob(s).first&.dirname.tap { |gem_dir| require gem_dir.join('lib/stibium/bundled') }
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
81
|
+
include(::Stibium::Bundled).bundled_from(basedir, setup: true) do |bundle|
|
82
|
+
if bundle.locked? and bundle.installed? and Object.const_defined?(:Gem)
|
83
|
+
require 'fabulous/feature' if bundle.specifications.keep_if { |s| s.name == 'fabulous' }.any?
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
```
|
89
|
+
|
90
|
+
## Benchmarks
|
91
|
+
|
92
|
+
Using ``Stibium::Bundled`` setup leads to minor overhead compared to direct require for ``bundler/setup``,
|
93
|
+
on the other hand ``Stibium::Bundled`` setup is compatible with standalone's bundler setup without code change.
|
94
|
+
And ``bundle exec`` is known to be [slow][stackoverflow/running-scripts-with-bundle-exec-is-slow].
|
95
|
+
|
96
|
+
Install [hypefine][sharkdp/hyperfine] and run benchmarks:
|
97
|
+
|
98
|
+
```shell
|
99
|
+
rake bench runs=20
|
100
|
+
```
|
101
|
+
|
102
|
+
| Command | Mean [ms] | Min [ms] | Max [ms] | Relative |
|
103
|
+
|:---|---:|---:|---:|---:|
|
104
|
+
| `bundler/setup` | 205.7 ± 7.1 | 200.1 | 232.5 | 1.00 ± 0.05 |
|
105
|
+
| `bundled` | 205.7 ± 6.2 | 196.8 | 222.4 | 1.00 |
|
106
|
+
| `bundle exec` | 559.4 ± 13.0 | 543.2 | 587.8 | 2.72 ± 0.10 |
|
107
|
+
|
65
108
|
## Install
|
66
109
|
|
67
110
|
```sh
|
@@ -76,3 +119,5 @@ bundle install --standalone
|
|
76
119
|
[bundler:config]: https://bundler.io/v2.2/bundle_config.html
|
77
120
|
[bundler:setup]: https://bundler.io/v1.5/bundler_setup.html
|
78
121
|
[man:install#options]: https://bundler.io/man/bundle-install.1.html#OPTIONS
|
122
|
+
[sharkdp/hyperfine]: https://github.com/sharkdp/hyperfine
|
123
|
+
[stackoverflow/running-scripts-with-bundle-exec-is-slow]: https://stackoverflow.com/questions/13894966/running-scripts-with-bundle-exec-is-slow
|
data/lib/stibium/bundled.rb
CHANGED
@@ -69,12 +69,10 @@ module Stibium::Bundled
|
|
69
69
|
# @see Stibium::Bundled::Bundle#setup
|
70
70
|
def bundled_from(basedir, setup: false, env: ENV.to_h, ruby_config: {})
|
71
71
|
# @type [Stibium::Bundled::Bundle] bundle
|
72
|
-
Stibium::Bundled.call(self, basedir: basedir, env: env, ruby_config: ruby_config).bundled
|
73
|
-
|
74
|
-
bundle.__send__(:setup, **(setup.is_a?(Array) ? { guards: setup } : {})) if setup
|
72
|
+
Stibium::Bundled.call(self, basedir: basedir, env: env, ruby_config: ruby_config).bundled&.tap do |bundle|
|
73
|
+
bundle.__send__(:setup, **{ guards: setup.is_a?(Array) ? setup : nil }.compact) if setup
|
75
74
|
|
76
|
-
|
77
|
-
end
|
75
|
+
yield(bundle) if block_given?
|
78
76
|
end
|
79
77
|
end
|
80
78
|
|
@@ -85,18 +83,29 @@ module Stibium::Bundled
|
|
85
83
|
# @param ruby_config [Hash{Symbol => Object}]
|
86
84
|
#
|
87
85
|
# @return [Class, Module] given ``Class`` or ``Module``
|
88
|
-
def call(target, basedir:, env: ENV.to_h, ruby_config:
|
86
|
+
def call(target, basedir:, env: ENV.to_h, ruby_config: nil)
|
89
87
|
target.tap do |t|
|
90
88
|
t.singleton_class.tap do |sc|
|
91
89
|
sc.singleton_class.__send__(:include, self)
|
92
90
|
sc.define_method(:bundled?) { !bundled.nil? }
|
93
91
|
sc.define_method(:bundled) do
|
94
|
-
|
95
|
-
Bundle.new(basedir, env: env, ruby_config: ruby_config)
|
96
|
-
.yield_self { |bundle| bundle.bundled? ? bundle : nil }
|
92
|
+
Stibium::Bundled.__send__(:bundler).call(basedir, env: env, ruby_config: ruby_config)
|
97
93
|
end
|
98
94
|
end
|
99
95
|
end
|
100
96
|
end
|
97
|
+
|
98
|
+
protected
|
99
|
+
|
100
|
+
# @api private
|
101
|
+
#
|
102
|
+
# @return [Proc]
|
103
|
+
def bundler
|
104
|
+
lambda do |basedir, env:, ruby_config: nil|
|
105
|
+
Bundle.new(basedir, env: env, ruby_config: ruby_config).yield_self do |bundle|
|
106
|
+
bundle.bundled? ? bundle : nil
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|
101
110
|
end
|
102
111
|
end
|
@@ -67,7 +67,7 @@ class Stibium::Bundled::Bundle
|
|
67
67
|
#
|
68
68
|
# @return [Array<Gem::Specification>]
|
69
69
|
def specifications
|
70
|
-
directory.specifications.map { |file| instance_eval(file.read, file.to_path) }
|
70
|
+
directory.specifications.map { |file| instance_eval(file.read, file.to_path) }.sort_by(&:name)
|
71
71
|
end
|
72
72
|
|
73
73
|
# Denote install seems to be happened (since specifications are present).
|
@@ -110,7 +110,7 @@ class Stibium::Bundled::Bundle
|
|
110
110
|
#
|
111
111
|
# @return [Boolean]
|
112
112
|
def standalone?
|
113
|
-
|
113
|
+
bundler_setup.yield_self { |fp| fp.file? and fp.readable? }
|
114
114
|
end
|
115
115
|
|
116
116
|
protected
|
@@ -119,14 +119,14 @@ class Stibium::Bundled::Bundle
|
|
119
119
|
#
|
120
120
|
# @return [self]
|
121
121
|
#
|
122
|
-
# @raise [Errno::ENOENT]
|
122
|
+
# @raise [Errno::ENOENT, LoadError]
|
123
123
|
def standalone!(&fallback)
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
124
|
+
# noinspection RubyResolve
|
125
|
+
require(bundler_setup.realpath)
|
126
|
+
rescue Errno::ENOENT, LoadError => e
|
127
|
+
fallback ? fallback.call(self) : raise(e)
|
128
|
+
ensure
|
129
|
+
self
|
130
130
|
end
|
131
131
|
|
132
132
|
# Load standalone setup if present, else fallback to <code>bundler/setup</code>.
|
@@ -146,12 +146,12 @@ class Stibium::Bundled::Bundle
|
|
146
146
|
# @see https://github.com/ruby/ruby/blob/0e40cc9b194a5e46024d32b85a61e651372a65cb/lib/bundler/setup.rb
|
147
147
|
# @see https://github.com/ruby/ruby/blob/69ed64949b0c02d4b195809fa104ff23dd100093/lib/bundler.rb#L11
|
148
148
|
# @see https://github.com/ruby/ruby/blob/69ed64949b0c02d4b195809fa104ff23dd100093/lib/bundler/rubygems_integration.rb
|
149
|
-
def setup(guards: [:
|
150
|
-
self.
|
151
|
-
guards.map { |s| self.public_send('%s?' % s.to_s.gsub(/\?$/, '')) }.
|
152
|
-
require 'bundler/setup'
|
149
|
+
def setup(guards: [:bundled, :installed])
|
150
|
+
self.tap do
|
151
|
+
unless guards.map { |s| self.public_send('%s?' % s.to_s.gsub(/\?$/, '')) }.include?(false)
|
152
|
+
standalone! { require 'bundler/setup' }
|
153
153
|
end
|
154
|
-
end
|
154
|
+
end
|
155
155
|
end
|
156
156
|
|
157
157
|
# Standalone setup file.
|
@@ -166,12 +166,10 @@ class Stibium::Bundled::Bundle
|
|
166
166
|
# @see #standalone!
|
167
167
|
# @see https://bundler.io/v2.2/man/bundle-install.1.html#OPTIONS
|
168
168
|
#
|
169
|
-
# @return [Pathname
|
169
|
+
# @return [Pathname]
|
170
170
|
def bundler_setup
|
171
171
|
Pathname.new(config.fetch('BUNDLE_PATH')).yield_self do |bundle_path|
|
172
|
-
(bundle_path.absolute? ? bundle_path : path.join(bundle_path)).join('bundler/setup.rb')
|
173
|
-
(file.file? and file.readable?) ? file : nil # rubocop:disable Style/TernaryParentheses
|
174
|
-
end
|
172
|
+
(bundle_path.absolute? ? bundle_path : path.join(bundle_path)).join('bundler/setup.rb')
|
175
173
|
end
|
176
174
|
end
|
177
175
|
end
|
@@ -27,6 +27,11 @@ require_relative '../bundle'
|
|
27
27
|
# @see .defaults
|
28
28
|
class Stibium::Bundled::Bundle::Config < ::Hash
|
29
29
|
autoload(:Pathname, 'pathname')
|
30
|
+
autoload(:YAML, 'yaml')
|
31
|
+
|
32
|
+
{
|
33
|
+
Reader: 'reader',
|
34
|
+
}.each { |k, v| autoload(k, "#{__dir__}/config/#{v}") }
|
30
35
|
|
31
36
|
# @param basedir [String, Pathname]
|
32
37
|
# @param env [Hash{String => String}]
|
@@ -63,9 +68,6 @@ class Stibium::Bundled::Bundle::Config < ::Hash
|
|
63
68
|
end
|
64
69
|
|
65
70
|
class << self
|
66
|
-
autoload(:Pathname, 'pathname')
|
67
|
-
autoload(:YAML, 'yaml')
|
68
|
-
|
69
71
|
# Default config values (as seen from an empty environment).
|
70
72
|
#
|
71
73
|
# ```shell
|
@@ -114,9 +116,7 @@ class Stibium::Bundled::Bundle::Config < ::Hash
|
|
114
116
|
env['HOME'].yield_self do |home_path|
|
115
117
|
return {} if home_path.nil?
|
116
118
|
|
117
|
-
Pathname.new(home_path).expand_path.join('.bundle/config').yield_self
|
118
|
-
self.read(file, env: env)
|
119
|
-
end
|
119
|
+
Pathname.new(home_path).expand_path.join('.bundle/config').yield_self { |file| self.read(file, env: env) }
|
120
120
|
end
|
121
121
|
end
|
122
122
|
|
@@ -143,12 +143,7 @@ class Stibium::Bundled::Bundle::Config < ::Hash
|
|
143
143
|
#
|
144
144
|
# @return [Hash{String => Object}]
|
145
145
|
def read(file, env: ENV.to_h)
|
146
|
-
|
147
|
-
|
148
|
-
return {} unless file.file? and file.readable?
|
149
|
-
|
150
|
-
(file.read.yield_self { |content| YAML.safe_load(content) })
|
151
|
-
.transform_values { |v| v.is_a?(String) ? YAML.safe_load(v) : v }
|
146
|
+
Reader.new(env: env).read(file)
|
152
147
|
end
|
153
148
|
end
|
154
149
|
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Copyright (C) 2020-2021 Dimitri Arrigoni <dimitri@arrigoni.me>
|
4
|
+
# License GPLv3+: GNU GPL version 3 or later
|
5
|
+
# <http://www.gnu.org/licenses/gpl.html>.
|
6
|
+
# This is free software: you are free to change and redistribute it.
|
7
|
+
# There is NO WARRANTY, to the extent permitted by law.
|
8
|
+
|
9
|
+
require_relative '../config'
|
10
|
+
|
11
|
+
# Config file reader.
|
12
|
+
class Stibium::Bundled::Bundle::Config::Reader
|
13
|
+
autoload(:YAML, 'yaml')
|
14
|
+
|
15
|
+
# @return [Hash{String => String}]
|
16
|
+
attr_reader :env
|
17
|
+
|
18
|
+
def initialize(env: ENV.to_h)
|
19
|
+
self.tap do
|
20
|
+
@env = env.dup.map { |k, v| [k.freeze, v.freeze] }.to_h.freeze
|
21
|
+
end.freeze
|
22
|
+
end
|
23
|
+
|
24
|
+
# @return [Boolean]
|
25
|
+
def ignore_config?
|
26
|
+
env.key?('BUNDLE_IGNORE_CONFIG')
|
27
|
+
end
|
28
|
+
|
29
|
+
# Read given config file.
|
30
|
+
#
|
31
|
+
# @param file [Pathname]
|
32
|
+
#
|
33
|
+
# @return [Hash{String => Object}]
|
34
|
+
def read(file)
|
35
|
+
scrutinize(file).transform_values { |v| v.is_a?(String) ? YAML.safe_load(v) : v }
|
36
|
+
end
|
37
|
+
|
38
|
+
protected
|
39
|
+
|
40
|
+
# @api private
|
41
|
+
#
|
42
|
+
# @param file [Pathname]
|
43
|
+
#
|
44
|
+
# @return [Hash{String => Object}]
|
45
|
+
def scrutinize(file)
|
46
|
+
return {} if ignore_config?
|
47
|
+
|
48
|
+
return {} unless file.file? and file.readable?
|
49
|
+
|
50
|
+
file.read.yield_self { |content| YAML.safe_load(content) }
|
51
|
+
end
|
52
|
+
end
|
@@ -35,11 +35,14 @@ class Stibium::Bundled::Bundle::Directory
|
|
35
35
|
|
36
36
|
# @return [Array<Pathname>]
|
37
37
|
def specifications
|
38
|
-
[
|
38
|
+
[
|
39
|
+
[ruby_config.fetch(:engine), ruby_config.fetch(:version), 'specifications', '*.gemspec'],
|
40
|
+
[ruby_config.fetch(:engine), ruby_config.fetch(:version), 'bundler', 'gems', '*/*.gemspec'],
|
41
|
+
].map do |parts|
|
39
42
|
self.path.join(*parts).yield_self do |s|
|
40
43
|
Dir.glob(s).sort.map { |fp| Pathname.new(fp) }.keep_if(&:file?)
|
41
44
|
end
|
42
|
-
end
|
45
|
+
end.flatten.sort
|
43
46
|
end
|
44
47
|
|
45
48
|
protected
|
@@ -7,8 +7,24 @@
|
|
7
7
|
# There is NO WARRANTY, to the extent permitted by law.
|
8
8
|
|
9
9
|
require_relative '../bundled'
|
10
|
-
require 'kamaze/version'
|
11
10
|
|
12
11
|
Stibium::Bundled.instance_eval do
|
13
|
-
|
12
|
+
autoload(:YAML, 'yaml')
|
13
|
+
autoload(:Pathname, 'pathname')
|
14
|
+
|
15
|
+
Pathname.new(__dir__).join('version.yml').tap do |file|
|
16
|
+
YAML.safe_load(file.read).yield_self do |v|
|
17
|
+
%w[major minor patch].map { |key| v.fetch(key) }.join('.')
|
18
|
+
end.tap do |version|
|
19
|
+
lambda do
|
20
|
+
require 'kamaze/version'
|
21
|
+
rescue LoadError
|
22
|
+
# :nocov:
|
23
|
+
version
|
24
|
+
# :nocov:
|
25
|
+
else
|
26
|
+
Kamaze::Version.new.freeze
|
27
|
+
end.tap { |func| self.const_set(:VERSION, func.call) }
|
28
|
+
end
|
29
|
+
end
|
14
30
|
end
|
@@ -1,12 +1,12 @@
|
|
1
1
|
---
|
2
2
|
major: 0
|
3
3
|
minor: 0
|
4
|
-
patch:
|
4
|
+
patch: 4
|
5
5
|
authors: ['Dimitri Arrigoni']
|
6
6
|
email: 'dimitri@arrigoni.me'
|
7
|
-
date: '2021-
|
7
|
+
date: '2021-02-07'
|
8
8
|
summary: 'Denote bundle state'
|
9
|
-
description: 'Denote bundle state
|
9
|
+
description: 'Denote bundle state and (optionally) load bundler/setup according to the configuration.'
|
10
10
|
homepage: 'https://github.com/SwagDevOps/stibium-bundled'
|
11
11
|
licenses: ['GPL-3.0']
|
12
12
|
license_header: |
|
metadata
CHANGED
@@ -1,30 +1,17 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: stibium-bundled
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Dimitri Arrigoni
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
12
|
-
dependencies:
|
13
|
-
|
14
|
-
|
15
|
-
requirement: !ruby/object:Gem::Requirement
|
16
|
-
requirements:
|
17
|
-
- - "~>"
|
18
|
-
- !ruby/object:Gem::Version
|
19
|
-
version: '1.0'
|
20
|
-
type: :runtime
|
21
|
-
prerelease: false
|
22
|
-
version_requirements: !ruby/object:Gem::Requirement
|
23
|
-
requirements:
|
24
|
-
- - "~>"
|
25
|
-
- !ruby/object:Gem::Version
|
26
|
-
version: '1.0'
|
27
|
-
description: Denote bundle state, based on conventions.
|
11
|
+
date: 2021-02-07 00:00:00.000000000 Z
|
12
|
+
dependencies: []
|
13
|
+
description: Denote bundle state and (optionally) load bundler/setup according to
|
14
|
+
the configuration.
|
28
15
|
email: dimitri@arrigoni.me
|
29
16
|
executables: []
|
30
17
|
extensions: []
|
@@ -36,6 +23,7 @@ files:
|
|
36
23
|
- lib/stibium/bundled.rb
|
37
24
|
- lib/stibium/bundled/bundle.rb
|
38
25
|
- lib/stibium/bundled/bundle/config.rb
|
26
|
+
- lib/stibium/bundled/bundle/config/reader.rb
|
39
27
|
- lib/stibium/bundled/bundle/directory.rb
|
40
28
|
- lib/stibium/bundled/version.rb
|
41
29
|
- lib/stibium/bundled/version.yml
|