bundler 1.17.2 → 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of bundler might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +799 -571
- data/LICENSE.md +18 -19
- data/README.md +9 -8
- data/bundler.gemspec +8 -25
- data/exe/bundle +19 -3
- data/lib/bundler.rb +202 -87
- data/lib/bundler/build_metadata.rb +3 -3
- data/lib/bundler/capistrano.rb +4 -4
- data/lib/bundler/cli.rb +178 -140
- data/lib/bundler/cli/add.rb +28 -16
- data/lib/bundler/cli/cache.rb +25 -13
- data/lib/bundler/cli/common.rb +11 -12
- data/lib/bundler/cli/config.rb +161 -86
- data/lib/bundler/cli/console.rb +1 -1
- data/lib/bundler/cli/doctor.rb +4 -4
- data/lib/bundler/cli/exec.rb +15 -18
- data/lib/bundler/cli/gem.rb +5 -5
- data/lib/bundler/cli/info.rb +17 -5
- data/lib/bundler/cli/init.rb +1 -1
- data/lib/bundler/cli/install.rb +11 -10
- data/lib/bundler/cli/issue.rb +3 -3
- data/lib/bundler/cli/open.rb +10 -6
- data/lib/bundler/cli/outdated.rb +85 -81
- data/lib/bundler/cli/plugin.rb +9 -2
- data/lib/bundler/cli/pristine.rb +1 -1
- data/lib/bundler/cli/show.rb +1 -1
- data/lib/bundler/cli/update.rb +32 -12
- data/lib/bundler/compact_index_client.rb +25 -9
- data/lib/bundler/compact_index_client/updater.rb +2 -6
- data/lib/bundler/current_ruby.rb +9 -7
- data/lib/bundler/definition.rb +35 -26
- data/lib/bundler/dependency.rb +16 -4
- data/lib/bundler/deployment.rb +1 -1
- data/lib/bundler/dsl.rb +16 -40
- data/lib/bundler/env.rb +8 -13
- data/lib/bundler/environment_preserver.rb +0 -1
- data/lib/bundler/feature_flag.rb +23 -34
- data/lib/bundler/fetcher.rb +16 -13
- data/lib/bundler/fetcher/compact_index.rb +26 -12
- data/lib/bundler/fetcher/dependency.rb +1 -1
- data/lib/bundler/fetcher/downloader.rb +5 -2
- data/lib/bundler/fetcher/index.rb +5 -3
- data/lib/bundler/friendly_errors.rb +6 -7
- data/lib/bundler/gem_helper.rb +40 -25
- data/lib/bundler/gem_helpers.rb +2 -4
- data/lib/bundler/gem_tasks.rb +1 -1
- data/lib/bundler/gem_version_promoter.rb +3 -3
- data/lib/bundler/graph.rb +2 -2
- data/lib/bundler/injector.rb +10 -8
- data/lib/bundler/inline.rb +40 -30
- data/lib/bundler/installer.rb +7 -14
- data/lib/bundler/installer/gem_installer.rb +5 -1
- data/lib/bundler/installer/parallel_installer.rb +4 -8
- data/lib/bundler/installer/standalone.rb +1 -2
- data/lib/bundler/lazy_specification.rb +2 -3
- data/lib/bundler/lockfile_parser.rb +14 -21
- data/lib/bundler/match_platform.rb +1 -1
- data/lib/bundler/mirror.rb +3 -3
- data/lib/bundler/plugin.rb +42 -29
- data/lib/bundler/plugin/api.rb +1 -1
- data/lib/bundler/plugin/api/source.rb +4 -6
- data/lib/bundler/plugin/index.rb +14 -3
- data/lib/bundler/plugin/installer.rb +28 -15
- data/lib/bundler/psyched_yaml.rb +1 -1
- data/lib/bundler/remote_specification.rb +0 -2
- data/lib/bundler/resolver.rb +72 -24
- data/lib/bundler/resolver/spec_group.rb +3 -2
- data/lib/bundler/retry.rb +2 -2
- data/lib/bundler/ruby_version.rb +4 -19
- data/lib/bundler/rubygems_ext.rb +11 -67
- data/lib/bundler/rubygems_gem_installer.rb +1 -1
- data/lib/bundler/rubygems_integration.rb +142 -402
- data/lib/bundler/runtime.rb +2 -9
- data/lib/bundler/settings.rb +22 -51
- data/lib/bundler/setup.rb +7 -13
- data/lib/bundler/shared_helpers.rb +51 -77
- data/lib/bundler/similarity_detector.rb +2 -2
- data/lib/bundler/source.rb +5 -5
- data/lib/bundler/source/git.rb +24 -17
- data/lib/bundler/source/git/git_proxy.rb +38 -41
- data/lib/bundler/source/metadata.rb +9 -5
- data/lib/bundler/source/path.rb +13 -8
- data/lib/bundler/source/rubygems.rb +14 -8
- data/lib/bundler/source/rubygems/remote.rb +2 -3
- data/lib/bundler/source_list.rb +9 -12
- data/lib/bundler/spec_set.rb +23 -12
- data/lib/bundler/stub_specification.rb +18 -30
- data/lib/bundler/templates/Executable.bundler +23 -14
- data/lib/bundler/templates/newgem/CODE_OF_CONDUCT.md.tt +3 -3
- data/lib/bundler/templates/newgem/Gemfile.tt +8 -2
- data/lib/bundler/templates/newgem/README.md.tt +4 -3
- data/lib/bundler/templates/newgem/newgem.gemspec.tt +6 -27
- data/lib/bundler/templates/newgem/test/test_helper.rb.tt +1 -1
- data/lib/bundler/templates/newgem/travis.yml.tt +0 -1
- data/lib/bundler/ui.rb +3 -3
- data/lib/bundler/ui/rg_proxy.rb +1 -1
- data/lib/bundler/ui/shell.rb +4 -8
- data/lib/bundler/uri_credentials_filter.rb +7 -3
- data/lib/bundler/vendor/connection_pool/lib/connection_pool.rb +161 -0
- data/lib/bundler/vendor/connection_pool/lib/connection_pool/monotonic_time.rb +66 -0
- data/lib/bundler/vendor/connection_pool/lib/connection_pool/timed_stack.rb +176 -0
- data/lib/bundler/vendor/connection_pool/lib/connection_pool/version.rb +3 -0
- data/lib/bundler/vendor/fileutils/lib/fileutils.rb +273 -147
- data/lib/bundler/vendor/molinillo/lib/molinillo.rb +6 -6
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +2 -2
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +1 -1
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +1 -1
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +1 -1
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +1 -1
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +6 -6
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +1 -1
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +1 -1
- data/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +30 -8
- data/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +1 -1
- data/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +4 -4
- data/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +2 -2
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +273 -304
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/connection.rb +40 -0
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/pool.rb +53 -0
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/timed_stack_multi.rb +79 -0
- data/lib/bundler/vendor/thor/lib/thor.rb +19 -4
- data/lib/bundler/vendor/thor/lib/thor/actions.rb +27 -12
- data/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +7 -17
- data/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +16 -7
- data/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +19 -8
- data/lib/bundler/vendor/thor/lib/thor/base.rb +54 -43
- data/lib/bundler/vendor/thor/lib/thor/command.rb +21 -14
- data/lib/bundler/vendor/thor/lib/thor/error.rb +78 -0
- data/lib/bundler/vendor/thor/lib/thor/group.rb +3 -3
- data/lib/bundler/vendor/thor/lib/thor/invocation.rb +1 -0
- data/lib/bundler/vendor/thor/lib/thor/line_editor.rb +2 -2
- data/lib/bundler/vendor/thor/lib/thor/line_editor/basic.rb +1 -1
- data/lib/bundler/vendor/thor/lib/thor/line_editor/readline.rb +6 -6
- data/lib/bundler/vendor/thor/lib/thor/nested_context.rb +29 -0
- data/lib/bundler/vendor/thor/lib/thor/parser.rb +4 -4
- data/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +2 -2
- data/lib/bundler/vendor/thor/lib/thor/parser/option.rb +20 -7
- data/lib/bundler/vendor/thor/lib/thor/parser/options.rb +20 -5
- data/lib/bundler/vendor/thor/lib/thor/rake_compat.rb +1 -0
- data/lib/bundler/vendor/thor/lib/thor/runner.rb +15 -14
- data/lib/bundler/vendor/thor/lib/thor/shell.rb +4 -4
- data/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +62 -8
- data/lib/bundler/vendor/thor/lib/thor/shell/color.rb +6 -2
- data/lib/bundler/vendor/thor/lib/thor/shell/html.rb +3 -3
- data/lib/bundler/vendor/thor/lib/thor/util.rb +18 -2
- data/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
- data/lib/bundler/vendor/uri/lib/uri.rb +104 -0
- data/lib/bundler/vendor/uri/lib/uri/common.rb +744 -0
- data/lib/bundler/vendor/uri/lib/uri/file.rb +94 -0
- data/lib/bundler/vendor/uri/lib/uri/ftp.rb +267 -0
- data/lib/bundler/vendor/uri/lib/uri/generic.rb +1568 -0
- data/lib/bundler/vendor/uri/lib/uri/http.rb +88 -0
- data/lib/bundler/vendor/uri/lib/uri/https.rb +23 -0
- data/lib/bundler/vendor/uri/lib/uri/ldap.rb +261 -0
- data/lib/bundler/vendor/uri/lib/uri/ldaps.rb +21 -0
- data/lib/bundler/vendor/uri/lib/uri/mailto.rb +294 -0
- data/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +546 -0
- data/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +125 -0
- data/lib/bundler/vendor/uri/lib/uri/version.rb +6 -0
- data/lib/bundler/vendored_fileutils.rb +1 -6
- data/lib/bundler/vendored_molinillo.rb +1 -1
- data/lib/bundler/vendored_persistent.rb +7 -5
- data/lib/bundler/vendored_thor.rb +2 -2
- data/lib/bundler/vendored_uri.rb +4 -0
- data/lib/bundler/version.rb +1 -20
- data/lib/bundler/version_ranges.rb +51 -5
- data/lib/bundler/vlad.rb +2 -2
- data/lib/bundler/worker.rb +1 -3
- data/lib/bundler/yaml_serializer.rb +2 -3
- data/man/bundle-add.1 +10 -2
- data/man/bundle-add.1.txt +11 -5
- data/man/bundle-add.ronn +7 -1
- data/man/bundle-binstubs.1 +2 -2
- data/man/bundle-binstubs.1.txt +2 -2
- data/man/bundle-binstubs.ronn +1 -1
- data/man/bundle-cache.1 +55 -0
- data/man/bundle-cache.1.txt +78 -0
- data/man/{bundle-package.ronn → bundle-cache.ronn} +15 -15
- data/man/bundle-check.1 +1 -1
- data/man/bundle-check.1.txt +6 -6
- data/man/bundle-clean.1 +1 -1
- data/man/bundle-clean.1.txt +1 -1
- data/man/bundle-config.1 +36 -36
- data/man/bundle-config.1.txt +66 -67
- data/man/bundle-config.ronn +42 -40
- data/man/bundle-doctor.1 +1 -1
- data/man/bundle-doctor.1.txt +1 -1
- data/man/bundle-exec.1 +2 -2
- data/man/bundle-exec.1.txt +2 -2
- data/man/bundle-exec.ronn +1 -1
- data/man/bundle-gem.1 +1 -1
- data/man/bundle-gem.1.txt +3 -3
- data/man/bundle-info.1 +1 -1
- data/man/bundle-info.1.txt +1 -1
- data/man/bundle-init.1 +2 -2
- data/man/bundle-init.1.txt +2 -2
- data/man/bundle-init.ronn +1 -1
- data/man/bundle-inject.1 +1 -1
- data/man/bundle-inject.1.txt +1 -1
- data/man/bundle-install.1 +8 -5
- data/man/bundle-install.1.txt +56 -51
- data/man/bundle-install.ronn +9 -4
- data/man/bundle-list.1 +1 -1
- data/man/bundle-list.1.txt +1 -1
- data/man/bundle-lock.1 +1 -1
- data/man/bundle-lock.1.txt +16 -16
- data/man/bundle-open.1 +1 -1
- data/man/bundle-open.1.txt +1 -1
- data/man/bundle-outdated.1 +1 -1
- data/man/bundle-outdated.1.txt +1 -1
- data/man/bundle-platform.1 +1 -1
- data/man/bundle-platform.1.txt +1 -1
- data/man/bundle-pristine.1 +1 -1
- data/man/bundle-pristine.1.txt +1 -1
- data/man/bundle-remove.1 +1 -1
- data/man/bundle-remove.1.txt +1 -1
- data/man/bundle-show.1 +1 -1
- data/man/bundle-show.1.txt +1 -1
- data/man/bundle-update.1 +4 -4
- data/man/bundle-update.1.txt +64 -65
- data/man/bundle-update.ronn +3 -3
- data/man/bundle-viz.1 +1 -1
- data/man/bundle-viz.1.txt +1 -1
- data/man/bundle.1 +7 -3
- data/man/bundle.1.txt +11 -8
- data/man/bundle.ronn +5 -2
- data/man/gemfile.5 +17 -20
- data/man/gemfile.5.ronn +14 -18
- data/man/gemfile.5.txt +108 -112
- data/man/index.txt +1 -1
- metadata +34 -110
- data/exe/bundle_ruby +0 -60
- data/lib/bundler/cli/package.rb +0 -49
- data/lib/bundler/compatibility_guard.rb +0 -14
- data/lib/bundler/gem_remote_fetcher.rb +0 -43
- data/lib/bundler/ssl_certs/.document +0 -1
- data/lib/bundler/ssl_certs/certificate_manager.rb +0 -66
- data/lib/bundler/ssl_certs/index.rubygems.org/GlobalSignRootCA.pem +0 -21
- data/lib/bundler/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +0 -23
- data/lib/bundler/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +0 -25
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/faster.rb +0 -27
- data/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent/ssl_reuse.rb +0 -129
- data/lib/bundler/vendor/thor/lib/thor/core_ext/io_binary_read.rb +0 -12
- data/lib/bundler/vendor/thor/lib/thor/core_ext/ordered_hash.rb +0 -129
- data/man/bundle-package.1 +0 -55
- data/man/bundle-package.1.txt +0 -79
@@ -0,0 +1,546 @@
|
|
1
|
+
# frozen_string_literal: false
|
2
|
+
#--
|
3
|
+
# = uri/common.rb
|
4
|
+
#
|
5
|
+
# Author:: Akira Yamada <akira@ruby-lang.org>
|
6
|
+
# Revision:: $Id$
|
7
|
+
# License::
|
8
|
+
# You can redistribute it and/or modify it under the same term as Ruby.
|
9
|
+
#
|
10
|
+
# See Bundler::URI for general documentation
|
11
|
+
#
|
12
|
+
|
13
|
+
module Bundler::URI
|
14
|
+
#
|
15
|
+
# Includes Bundler::URI::REGEXP::PATTERN
|
16
|
+
#
|
17
|
+
module RFC2396_REGEXP
|
18
|
+
#
|
19
|
+
# Patterns used to parse Bundler::URI's
|
20
|
+
#
|
21
|
+
module PATTERN
|
22
|
+
# :stopdoc:
|
23
|
+
|
24
|
+
# RFC 2396 (Bundler::URI Generic Syntax)
|
25
|
+
# RFC 2732 (IPv6 Literal Addresses in URL's)
|
26
|
+
# RFC 2373 (IPv6 Addressing Architecture)
|
27
|
+
|
28
|
+
# alpha = lowalpha | upalpha
|
29
|
+
ALPHA = "a-zA-Z"
|
30
|
+
# alphanum = alpha | digit
|
31
|
+
ALNUM = "#{ALPHA}\\d"
|
32
|
+
|
33
|
+
# hex = digit | "A" | "B" | "C" | "D" | "E" | "F" |
|
34
|
+
# "a" | "b" | "c" | "d" | "e" | "f"
|
35
|
+
HEX = "a-fA-F\\d"
|
36
|
+
# escaped = "%" hex hex
|
37
|
+
ESCAPED = "%[#{HEX}]{2}"
|
38
|
+
# mark = "-" | "_" | "." | "!" | "~" | "*" | "'" |
|
39
|
+
# "(" | ")"
|
40
|
+
# unreserved = alphanum | mark
|
41
|
+
UNRESERVED = "\\-_.!~*'()#{ALNUM}"
|
42
|
+
# reserved = ";" | "/" | "?" | ":" | "@" | "&" | "=" | "+" |
|
43
|
+
# "$" | ","
|
44
|
+
# reserved = ";" | "/" | "?" | ":" | "@" | "&" | "=" | "+" |
|
45
|
+
# "$" | "," | "[" | "]" (RFC 2732)
|
46
|
+
RESERVED = ";/?:@&=+$,\\[\\]"
|
47
|
+
|
48
|
+
# domainlabel = alphanum | alphanum *( alphanum | "-" ) alphanum
|
49
|
+
DOMLABEL = "(?:[#{ALNUM}](?:[-#{ALNUM}]*[#{ALNUM}])?)"
|
50
|
+
# toplabel = alpha | alpha *( alphanum | "-" ) alphanum
|
51
|
+
TOPLABEL = "(?:[#{ALPHA}](?:[-#{ALNUM}]*[#{ALNUM}])?)"
|
52
|
+
# hostname = *( domainlabel "." ) toplabel [ "." ]
|
53
|
+
HOSTNAME = "(?:#{DOMLABEL}\\.)*#{TOPLABEL}\\.?"
|
54
|
+
|
55
|
+
# :startdoc:
|
56
|
+
end # PATTERN
|
57
|
+
|
58
|
+
# :startdoc:
|
59
|
+
end # REGEXP
|
60
|
+
|
61
|
+
# Class that parses String's into Bundler::URI's.
|
62
|
+
#
|
63
|
+
# It contains a Hash set of patterns and Regexp's that match and validate.
|
64
|
+
#
|
65
|
+
class RFC2396_Parser
|
66
|
+
include RFC2396_REGEXP
|
67
|
+
|
68
|
+
#
|
69
|
+
# == Synopsis
|
70
|
+
#
|
71
|
+
# Bundler::URI::Parser.new([opts])
|
72
|
+
#
|
73
|
+
# == Args
|
74
|
+
#
|
75
|
+
# The constructor accepts a hash as options for parser.
|
76
|
+
# Keys of options are pattern names of Bundler::URI components
|
77
|
+
# and values of options are pattern strings.
|
78
|
+
# The constructor generates set of regexps for parsing URIs.
|
79
|
+
#
|
80
|
+
# You can use the following keys:
|
81
|
+
#
|
82
|
+
# * :ESCAPED (Bundler::URI::PATTERN::ESCAPED in default)
|
83
|
+
# * :UNRESERVED (Bundler::URI::PATTERN::UNRESERVED in default)
|
84
|
+
# * :DOMLABEL (Bundler::URI::PATTERN::DOMLABEL in default)
|
85
|
+
# * :TOPLABEL (Bundler::URI::PATTERN::TOPLABEL in default)
|
86
|
+
# * :HOSTNAME (Bundler::URI::PATTERN::HOSTNAME in default)
|
87
|
+
#
|
88
|
+
# == Examples
|
89
|
+
#
|
90
|
+
# p = Bundler::URI::Parser.new(:ESCAPED => "(?:%[a-fA-F0-9]{2}|%u[a-fA-F0-9]{4})")
|
91
|
+
# u = p.parse("http://example.jp/%uABCD") #=> #<Bundler::URI::HTTP http://example.jp/%uABCD>
|
92
|
+
# Bundler::URI.parse(u.to_s) #=> raises Bundler::URI::InvalidURIError
|
93
|
+
#
|
94
|
+
# s = "http://example.com/ABCD"
|
95
|
+
# u1 = p.parse(s) #=> #<Bundler::URI::HTTP http://example.com/ABCD>
|
96
|
+
# u2 = Bundler::URI.parse(s) #=> #<Bundler::URI::HTTP http://example.com/ABCD>
|
97
|
+
# u1 == u2 #=> true
|
98
|
+
# u1.eql?(u2) #=> false
|
99
|
+
#
|
100
|
+
def initialize(opts = {})
|
101
|
+
@pattern = initialize_pattern(opts)
|
102
|
+
@pattern.each_value(&:freeze)
|
103
|
+
@pattern.freeze
|
104
|
+
|
105
|
+
@regexp = initialize_regexp(@pattern)
|
106
|
+
@regexp.each_value(&:freeze)
|
107
|
+
@regexp.freeze
|
108
|
+
end
|
109
|
+
|
110
|
+
# The Hash of patterns.
|
111
|
+
#
|
112
|
+
# See also Bundler::URI::Parser.initialize_pattern.
|
113
|
+
attr_reader :pattern
|
114
|
+
|
115
|
+
# The Hash of Regexp.
|
116
|
+
#
|
117
|
+
# See also Bundler::URI::Parser.initialize_regexp.
|
118
|
+
attr_reader :regexp
|
119
|
+
|
120
|
+
# Returns a split Bundler::URI against regexp[:ABS_URI].
|
121
|
+
def split(uri)
|
122
|
+
case uri
|
123
|
+
when ''
|
124
|
+
# null uri
|
125
|
+
|
126
|
+
when @regexp[:ABS_URI]
|
127
|
+
scheme, opaque, userinfo, host, port,
|
128
|
+
registry, path, query, fragment = $~[1..-1]
|
129
|
+
|
130
|
+
# Bundler::URI-reference = [ absoluteURI | relativeURI ] [ "#" fragment ]
|
131
|
+
|
132
|
+
# absoluteURI = scheme ":" ( hier_part | opaque_part )
|
133
|
+
# hier_part = ( net_path | abs_path ) [ "?" query ]
|
134
|
+
# opaque_part = uric_no_slash *uric
|
135
|
+
|
136
|
+
# abs_path = "/" path_segments
|
137
|
+
# net_path = "//" authority [ abs_path ]
|
138
|
+
|
139
|
+
# authority = server | reg_name
|
140
|
+
# server = [ [ userinfo "@" ] hostport ]
|
141
|
+
|
142
|
+
if !scheme
|
143
|
+
raise InvalidURIError,
|
144
|
+
"bad Bundler::URI(absolute but no scheme): #{uri}"
|
145
|
+
end
|
146
|
+
if !opaque && (!path && (!host && !registry))
|
147
|
+
raise InvalidURIError,
|
148
|
+
"bad Bundler::URI(absolute but no path): #{uri}"
|
149
|
+
end
|
150
|
+
|
151
|
+
when @regexp[:REL_URI]
|
152
|
+
scheme = nil
|
153
|
+
opaque = nil
|
154
|
+
|
155
|
+
userinfo, host, port, registry,
|
156
|
+
rel_segment, abs_path, query, fragment = $~[1..-1]
|
157
|
+
if rel_segment && abs_path
|
158
|
+
path = rel_segment + abs_path
|
159
|
+
elsif rel_segment
|
160
|
+
path = rel_segment
|
161
|
+
elsif abs_path
|
162
|
+
path = abs_path
|
163
|
+
end
|
164
|
+
|
165
|
+
# Bundler::URI-reference = [ absoluteURI | relativeURI ] [ "#" fragment ]
|
166
|
+
|
167
|
+
# relativeURI = ( net_path | abs_path | rel_path ) [ "?" query ]
|
168
|
+
|
169
|
+
# net_path = "//" authority [ abs_path ]
|
170
|
+
# abs_path = "/" path_segments
|
171
|
+
# rel_path = rel_segment [ abs_path ]
|
172
|
+
|
173
|
+
# authority = server | reg_name
|
174
|
+
# server = [ [ userinfo "@" ] hostport ]
|
175
|
+
|
176
|
+
else
|
177
|
+
raise InvalidURIError, "bad Bundler::URI(is not Bundler::URI?): #{uri}"
|
178
|
+
end
|
179
|
+
|
180
|
+
path = '' if !path && !opaque # (see RFC2396 Section 5.2)
|
181
|
+
ret = [
|
182
|
+
scheme,
|
183
|
+
userinfo, host, port, # X
|
184
|
+
registry, # X
|
185
|
+
path, # Y
|
186
|
+
opaque, # Y
|
187
|
+
query,
|
188
|
+
fragment
|
189
|
+
]
|
190
|
+
return ret
|
191
|
+
end
|
192
|
+
|
193
|
+
#
|
194
|
+
# == Args
|
195
|
+
#
|
196
|
+
# +uri+::
|
197
|
+
# String
|
198
|
+
#
|
199
|
+
# == Description
|
200
|
+
#
|
201
|
+
# Parses +uri+ and constructs either matching Bundler::URI scheme object
|
202
|
+
# (File, FTP, HTTP, HTTPS, LDAP, LDAPS, or MailTo) or Bundler::URI::Generic.
|
203
|
+
#
|
204
|
+
# == Usage
|
205
|
+
#
|
206
|
+
# p = Bundler::URI::Parser.new
|
207
|
+
# p.parse("ldap://ldap.example.com/dc=example?user=john")
|
208
|
+
# #=> #<Bundler::URI::LDAP ldap://ldap.example.com/dc=example?user=john>
|
209
|
+
#
|
210
|
+
def parse(uri)
|
211
|
+
scheme, userinfo, host, port,
|
212
|
+
registry, path, opaque, query, fragment = self.split(uri)
|
213
|
+
|
214
|
+
if scheme && Bundler::URI.scheme_list.include?(scheme.upcase)
|
215
|
+
Bundler::URI.scheme_list[scheme.upcase].new(scheme, userinfo, host, port,
|
216
|
+
registry, path, opaque, query,
|
217
|
+
fragment, self)
|
218
|
+
else
|
219
|
+
Generic.new(scheme, userinfo, host, port,
|
220
|
+
registry, path, opaque, query,
|
221
|
+
fragment, self)
|
222
|
+
end
|
223
|
+
end
|
224
|
+
|
225
|
+
|
226
|
+
#
|
227
|
+
# == Args
|
228
|
+
#
|
229
|
+
# +uris+::
|
230
|
+
# an Array of Strings
|
231
|
+
#
|
232
|
+
# == Description
|
233
|
+
#
|
234
|
+
# Attempts to parse and merge a set of URIs.
|
235
|
+
#
|
236
|
+
def join(*uris)
|
237
|
+
uris[0] = convert_to_uri(uris[0])
|
238
|
+
uris.inject :merge
|
239
|
+
end
|
240
|
+
|
241
|
+
#
|
242
|
+
# :call-seq:
|
243
|
+
# extract( str )
|
244
|
+
# extract( str, schemes )
|
245
|
+
# extract( str, schemes ) {|item| block }
|
246
|
+
#
|
247
|
+
# == Args
|
248
|
+
#
|
249
|
+
# +str+::
|
250
|
+
# String to search
|
251
|
+
# +schemes+::
|
252
|
+
# Patterns to apply to +str+
|
253
|
+
#
|
254
|
+
# == Description
|
255
|
+
#
|
256
|
+
# Attempts to parse and merge a set of URIs.
|
257
|
+
# If no +block+ given, then returns the result,
|
258
|
+
# else it calls +block+ for each element in result.
|
259
|
+
#
|
260
|
+
# See also Bundler::URI::Parser.make_regexp.
|
261
|
+
#
|
262
|
+
def extract(str, schemes = nil)
|
263
|
+
if block_given?
|
264
|
+
str.scan(make_regexp(schemes)) { yield $& }
|
265
|
+
nil
|
266
|
+
else
|
267
|
+
result = []
|
268
|
+
str.scan(make_regexp(schemes)) { result.push $& }
|
269
|
+
result
|
270
|
+
end
|
271
|
+
end
|
272
|
+
|
273
|
+
# Returns Regexp that is default self.regexp[:ABS_URI_REF],
|
274
|
+
# unless +schemes+ is provided. Then it is a Regexp.union with self.pattern[:X_ABS_URI].
|
275
|
+
def make_regexp(schemes = nil)
|
276
|
+
unless schemes
|
277
|
+
@regexp[:ABS_URI_REF]
|
278
|
+
else
|
279
|
+
/(?=#{Regexp.union(*schemes)}:)#{@pattern[:X_ABS_URI]}/x
|
280
|
+
end
|
281
|
+
end
|
282
|
+
|
283
|
+
#
|
284
|
+
# :call-seq:
|
285
|
+
# escape( str )
|
286
|
+
# escape( str, unsafe )
|
287
|
+
#
|
288
|
+
# == Args
|
289
|
+
#
|
290
|
+
# +str+::
|
291
|
+
# String to make safe
|
292
|
+
# +unsafe+::
|
293
|
+
# Regexp to apply. Defaults to self.regexp[:UNSAFE]
|
294
|
+
#
|
295
|
+
# == Description
|
296
|
+
#
|
297
|
+
# Constructs a safe String from +str+, removing unsafe characters,
|
298
|
+
# replacing them with codes.
|
299
|
+
#
|
300
|
+
def escape(str, unsafe = @regexp[:UNSAFE])
|
301
|
+
unless unsafe.kind_of?(Regexp)
|
302
|
+
# perhaps unsafe is String object
|
303
|
+
unsafe = Regexp.new("[#{Regexp.quote(unsafe)}]", false)
|
304
|
+
end
|
305
|
+
str.gsub(unsafe) do
|
306
|
+
us = $&
|
307
|
+
tmp = ''
|
308
|
+
us.each_byte do |uc|
|
309
|
+
tmp << sprintf('%%%02X', uc)
|
310
|
+
end
|
311
|
+
tmp
|
312
|
+
end.force_encoding(Encoding::US_ASCII)
|
313
|
+
end
|
314
|
+
|
315
|
+
#
|
316
|
+
# :call-seq:
|
317
|
+
# unescape( str )
|
318
|
+
# unescape( str, escaped )
|
319
|
+
#
|
320
|
+
# == Args
|
321
|
+
#
|
322
|
+
# +str+::
|
323
|
+
# String to remove escapes from
|
324
|
+
# +escaped+::
|
325
|
+
# Regexp to apply. Defaults to self.regexp[:ESCAPED]
|
326
|
+
#
|
327
|
+
# == Description
|
328
|
+
#
|
329
|
+
# Removes escapes from +str+.
|
330
|
+
#
|
331
|
+
def unescape(str, escaped = @regexp[:ESCAPED])
|
332
|
+
enc = str.encoding
|
333
|
+
enc = Encoding::UTF_8 if enc == Encoding::US_ASCII
|
334
|
+
str.gsub(escaped) { [$&[1, 2]].pack('H2').force_encoding(enc) }
|
335
|
+
end
|
336
|
+
|
337
|
+
@@to_s = Kernel.instance_method(:to_s)
|
338
|
+
def inspect
|
339
|
+
@@to_s.bind_call(self)
|
340
|
+
end
|
341
|
+
|
342
|
+
private
|
343
|
+
|
344
|
+
# Constructs the default Hash of patterns.
|
345
|
+
def initialize_pattern(opts = {})
|
346
|
+
ret = {}
|
347
|
+
ret[:ESCAPED] = escaped = (opts.delete(:ESCAPED) || PATTERN::ESCAPED)
|
348
|
+
ret[:UNRESERVED] = unreserved = opts.delete(:UNRESERVED) || PATTERN::UNRESERVED
|
349
|
+
ret[:RESERVED] = reserved = opts.delete(:RESERVED) || PATTERN::RESERVED
|
350
|
+
ret[:DOMLABEL] = opts.delete(:DOMLABEL) || PATTERN::DOMLABEL
|
351
|
+
ret[:TOPLABEL] = opts.delete(:TOPLABEL) || PATTERN::TOPLABEL
|
352
|
+
ret[:HOSTNAME] = hostname = opts.delete(:HOSTNAME)
|
353
|
+
|
354
|
+
# RFC 2396 (Bundler::URI Generic Syntax)
|
355
|
+
# RFC 2732 (IPv6 Literal Addresses in URL's)
|
356
|
+
# RFC 2373 (IPv6 Addressing Architecture)
|
357
|
+
|
358
|
+
# uric = reserved | unreserved | escaped
|
359
|
+
ret[:URIC] = uric = "(?:[#{unreserved}#{reserved}]|#{escaped})"
|
360
|
+
# uric_no_slash = unreserved | escaped | ";" | "?" | ":" | "@" |
|
361
|
+
# "&" | "=" | "+" | "$" | ","
|
362
|
+
ret[:URIC_NO_SLASH] = uric_no_slash = "(?:[#{unreserved};?:@&=+$,]|#{escaped})"
|
363
|
+
# query = *uric
|
364
|
+
ret[:QUERY] = query = "#{uric}*"
|
365
|
+
# fragment = *uric
|
366
|
+
ret[:FRAGMENT] = fragment = "#{uric}*"
|
367
|
+
|
368
|
+
# hostname = *( domainlabel "." ) toplabel [ "." ]
|
369
|
+
# reg-name = *( unreserved / pct-encoded / sub-delims ) # RFC3986
|
370
|
+
unless hostname
|
371
|
+
ret[:HOSTNAME] = hostname = "(?:[a-zA-Z0-9\\-.]|%\\h\\h)+"
|
372
|
+
end
|
373
|
+
|
374
|
+
# RFC 2373, APPENDIX B:
|
375
|
+
# IPv6address = hexpart [ ":" IPv4address ]
|
376
|
+
# IPv4address = 1*3DIGIT "." 1*3DIGIT "." 1*3DIGIT "." 1*3DIGIT
|
377
|
+
# hexpart = hexseq | hexseq "::" [ hexseq ] | "::" [ hexseq ]
|
378
|
+
# hexseq = hex4 *( ":" hex4)
|
379
|
+
# hex4 = 1*4HEXDIG
|
380
|
+
#
|
381
|
+
# XXX: This definition has a flaw. "::" + IPv4address must be
|
382
|
+
# allowed too. Here is a replacement.
|
383
|
+
#
|
384
|
+
# IPv4address = 1*3DIGIT "." 1*3DIGIT "." 1*3DIGIT "." 1*3DIGIT
|
385
|
+
ret[:IPV4ADDR] = ipv4addr = "\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}"
|
386
|
+
# hex4 = 1*4HEXDIG
|
387
|
+
hex4 = "[#{PATTERN::HEX}]{1,4}"
|
388
|
+
# lastpart = hex4 | IPv4address
|
389
|
+
lastpart = "(?:#{hex4}|#{ipv4addr})"
|
390
|
+
# hexseq1 = *( hex4 ":" ) hex4
|
391
|
+
hexseq1 = "(?:#{hex4}:)*#{hex4}"
|
392
|
+
# hexseq2 = *( hex4 ":" ) lastpart
|
393
|
+
hexseq2 = "(?:#{hex4}:)*#{lastpart}"
|
394
|
+
# IPv6address = hexseq2 | [ hexseq1 ] "::" [ hexseq2 ]
|
395
|
+
ret[:IPV6ADDR] = ipv6addr = "(?:#{hexseq2}|(?:#{hexseq1})?::(?:#{hexseq2})?)"
|
396
|
+
|
397
|
+
# IPv6prefix = ( hexseq1 | [ hexseq1 ] "::" [ hexseq1 ] ) "/" 1*2DIGIT
|
398
|
+
# unused
|
399
|
+
|
400
|
+
# ipv6reference = "[" IPv6address "]" (RFC 2732)
|
401
|
+
ret[:IPV6REF] = ipv6ref = "\\[#{ipv6addr}\\]"
|
402
|
+
|
403
|
+
# host = hostname | IPv4address
|
404
|
+
# host = hostname | IPv4address | IPv6reference (RFC 2732)
|
405
|
+
ret[:HOST] = host = "(?:#{hostname}|#{ipv4addr}|#{ipv6ref})"
|
406
|
+
# port = *digit
|
407
|
+
ret[:PORT] = port = '\d*'
|
408
|
+
# hostport = host [ ":" port ]
|
409
|
+
ret[:HOSTPORT] = hostport = "#{host}(?::#{port})?"
|
410
|
+
|
411
|
+
# userinfo = *( unreserved | escaped |
|
412
|
+
# ";" | ":" | "&" | "=" | "+" | "$" | "," )
|
413
|
+
ret[:USERINFO] = userinfo = "(?:[#{unreserved};:&=+$,]|#{escaped})*"
|
414
|
+
|
415
|
+
# pchar = unreserved | escaped |
|
416
|
+
# ":" | "@" | "&" | "=" | "+" | "$" | ","
|
417
|
+
pchar = "(?:[#{unreserved}:@&=+$,]|#{escaped})"
|
418
|
+
# param = *pchar
|
419
|
+
param = "#{pchar}*"
|
420
|
+
# segment = *pchar *( ";" param )
|
421
|
+
segment = "#{pchar}*(?:;#{param})*"
|
422
|
+
# path_segments = segment *( "/" segment )
|
423
|
+
ret[:PATH_SEGMENTS] = path_segments = "#{segment}(?:/#{segment})*"
|
424
|
+
|
425
|
+
# server = [ [ userinfo "@" ] hostport ]
|
426
|
+
server = "(?:#{userinfo}@)?#{hostport}"
|
427
|
+
# reg_name = 1*( unreserved | escaped | "$" | "," |
|
428
|
+
# ";" | ":" | "@" | "&" | "=" | "+" )
|
429
|
+
ret[:REG_NAME] = reg_name = "(?:[#{unreserved}$,;:@&=+]|#{escaped})+"
|
430
|
+
# authority = server | reg_name
|
431
|
+
authority = "(?:#{server}|#{reg_name})"
|
432
|
+
|
433
|
+
# rel_segment = 1*( unreserved | escaped |
|
434
|
+
# ";" | "@" | "&" | "=" | "+" | "$" | "," )
|
435
|
+
ret[:REL_SEGMENT] = rel_segment = "(?:[#{unreserved};@&=+$,]|#{escaped})+"
|
436
|
+
|
437
|
+
# scheme = alpha *( alpha | digit | "+" | "-" | "." )
|
438
|
+
ret[:SCHEME] = scheme = "[#{PATTERN::ALPHA}][\\-+.#{PATTERN::ALPHA}\\d]*"
|
439
|
+
|
440
|
+
# abs_path = "/" path_segments
|
441
|
+
ret[:ABS_PATH] = abs_path = "/#{path_segments}"
|
442
|
+
# rel_path = rel_segment [ abs_path ]
|
443
|
+
ret[:REL_PATH] = rel_path = "#{rel_segment}(?:#{abs_path})?"
|
444
|
+
# net_path = "//" authority [ abs_path ]
|
445
|
+
ret[:NET_PATH] = net_path = "//#{authority}(?:#{abs_path})?"
|
446
|
+
|
447
|
+
# hier_part = ( net_path | abs_path ) [ "?" query ]
|
448
|
+
ret[:HIER_PART] = hier_part = "(?:#{net_path}|#{abs_path})(?:\\?(?:#{query}))?"
|
449
|
+
# opaque_part = uric_no_slash *uric
|
450
|
+
ret[:OPAQUE_PART] = opaque_part = "#{uric_no_slash}#{uric}*"
|
451
|
+
|
452
|
+
# absoluteURI = scheme ":" ( hier_part | opaque_part )
|
453
|
+
ret[:ABS_URI] = abs_uri = "#{scheme}:(?:#{hier_part}|#{opaque_part})"
|
454
|
+
# relativeURI = ( net_path | abs_path | rel_path ) [ "?" query ]
|
455
|
+
ret[:REL_URI] = rel_uri = "(?:#{net_path}|#{abs_path}|#{rel_path})(?:\\?#{query})?"
|
456
|
+
|
457
|
+
# Bundler::URI-reference = [ absoluteURI | relativeURI ] [ "#" fragment ]
|
458
|
+
ret[:URI_REF] = "(?:#{abs_uri}|#{rel_uri})?(?:##{fragment})?"
|
459
|
+
|
460
|
+
ret[:X_ABS_URI] = "
|
461
|
+
(#{scheme}): (?# 1: scheme)
|
462
|
+
(?:
|
463
|
+
(#{opaque_part}) (?# 2: opaque)
|
464
|
+
|
|
465
|
+
(?:(?:
|
466
|
+
//(?:
|
467
|
+
(?:(?:(#{userinfo})@)? (?# 3: userinfo)
|
468
|
+
(?:(#{host})(?::(\\d*))?))? (?# 4: host, 5: port)
|
469
|
+
|
|
470
|
+
(#{reg_name}) (?# 6: registry)
|
471
|
+
)
|
472
|
+
|
|
473
|
+
(?!//)) (?# XXX: '//' is the mark for hostport)
|
474
|
+
(#{abs_path})? (?# 7: path)
|
475
|
+
)(?:\\?(#{query}))? (?# 8: query)
|
476
|
+
)
|
477
|
+
(?:\\#(#{fragment}))? (?# 9: fragment)
|
478
|
+
"
|
479
|
+
|
480
|
+
ret[:X_REL_URI] = "
|
481
|
+
(?:
|
482
|
+
(?:
|
483
|
+
//
|
484
|
+
(?:
|
485
|
+
(?:(#{userinfo})@)? (?# 1: userinfo)
|
486
|
+
(#{host})?(?::(\\d*))? (?# 2: host, 3: port)
|
487
|
+
|
|
488
|
+
(#{reg_name}) (?# 4: registry)
|
489
|
+
)
|
490
|
+
)
|
491
|
+
|
|
492
|
+
(#{rel_segment}) (?# 5: rel_segment)
|
493
|
+
)?
|
494
|
+
(#{abs_path})? (?# 6: abs_path)
|
495
|
+
(?:\\?(#{query}))? (?# 7: query)
|
496
|
+
(?:\\#(#{fragment}))? (?# 8: fragment)
|
497
|
+
"
|
498
|
+
|
499
|
+
ret
|
500
|
+
end
|
501
|
+
|
502
|
+
# Constructs the default Hash of Regexp's.
|
503
|
+
def initialize_regexp(pattern)
|
504
|
+
ret = {}
|
505
|
+
|
506
|
+
# for Bundler::URI::split
|
507
|
+
ret[:ABS_URI] = Regexp.new('\A\s*' + pattern[:X_ABS_URI] + '\s*\z', Regexp::EXTENDED)
|
508
|
+
ret[:REL_URI] = Regexp.new('\A\s*' + pattern[:X_REL_URI] + '\s*\z', Regexp::EXTENDED)
|
509
|
+
|
510
|
+
# for Bundler::URI::extract
|
511
|
+
ret[:URI_REF] = Regexp.new(pattern[:URI_REF])
|
512
|
+
ret[:ABS_URI_REF] = Regexp.new(pattern[:X_ABS_URI], Regexp::EXTENDED)
|
513
|
+
ret[:REL_URI_REF] = Regexp.new(pattern[:X_REL_URI], Regexp::EXTENDED)
|
514
|
+
|
515
|
+
# for Bundler::URI::escape/unescape
|
516
|
+
ret[:ESCAPED] = Regexp.new(pattern[:ESCAPED])
|
517
|
+
ret[:UNSAFE] = Regexp.new("[^#{pattern[:UNRESERVED]}#{pattern[:RESERVED]}]")
|
518
|
+
|
519
|
+
# for Generic#initialize
|
520
|
+
ret[:SCHEME] = Regexp.new("\\A#{pattern[:SCHEME]}\\z")
|
521
|
+
ret[:USERINFO] = Regexp.new("\\A#{pattern[:USERINFO]}\\z")
|
522
|
+
ret[:HOST] = Regexp.new("\\A#{pattern[:HOST]}\\z")
|
523
|
+
ret[:PORT] = Regexp.new("\\A#{pattern[:PORT]}\\z")
|
524
|
+
ret[:OPAQUE] = Regexp.new("\\A#{pattern[:OPAQUE_PART]}\\z")
|
525
|
+
ret[:REGISTRY] = Regexp.new("\\A#{pattern[:REG_NAME]}\\z")
|
526
|
+
ret[:ABS_PATH] = Regexp.new("\\A#{pattern[:ABS_PATH]}\\z")
|
527
|
+
ret[:REL_PATH] = Regexp.new("\\A#{pattern[:REL_PATH]}\\z")
|
528
|
+
ret[:QUERY] = Regexp.new("\\A#{pattern[:QUERY]}\\z")
|
529
|
+
ret[:FRAGMENT] = Regexp.new("\\A#{pattern[:FRAGMENT]}\\z")
|
530
|
+
|
531
|
+
ret
|
532
|
+
end
|
533
|
+
|
534
|
+
def convert_to_uri(uri)
|
535
|
+
if uri.is_a?(Bundler::URI::Generic)
|
536
|
+
uri
|
537
|
+
elsif uri = String.try_convert(uri)
|
538
|
+
parse(uri)
|
539
|
+
else
|
540
|
+
raise ArgumentError,
|
541
|
+
"bad argument (expected Bundler::URI object or Bundler::URI string)"
|
542
|
+
end
|
543
|
+
end
|
544
|
+
|
545
|
+
end # class Parser
|
546
|
+
end # module Bundler::URI
|