xqsr3 0.38.1.1 → 0.39.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (112) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +15 -6
  3. data/examples/count_word_frequencies.md +13 -13
  4. data/examples/count_word_frequencies.rb +5 -5
  5. data/lib/xqsr3/array_utilities/join_with_or.rb +53 -54
  6. data/lib/xqsr3/array_utilities.rb +2 -2
  7. data/lib/xqsr3/command_line_utilities/map_option_string.rb +66 -67
  8. data/lib/xqsr3/command_line_utilities.rb +2 -2
  9. data/lib/xqsr3/containers/frequency_map.rb +405 -404
  10. data/lib/xqsr3/containers/multi_map.rb +454 -453
  11. data/lib/xqsr3/containers.rb +3 -3
  12. data/lib/xqsr3/conversion/bool_parser.rb +56 -57
  13. data/lib/xqsr3/conversion/integer_parser.rb +92 -93
  14. data/lib/xqsr3/conversion.rb +3 -3
  15. data/lib/xqsr3/diagnostics/exception_utilities.rb +152 -151
  16. data/lib/xqsr3/diagnostics/exceptions/with_cause.rb +99 -95
  17. data/lib/xqsr3/diagnostics/inspect_builder.rb +86 -86
  18. data/lib/xqsr3/diagnostics.rb +3 -3
  19. data/lib/xqsr3/doc_.rb +136 -136
  20. data/lib/xqsr3/extensions/array/join_with_or.rb +9 -9
  21. data/lib/xqsr3/extensions/enumerable/collect_with_index.rb +18 -17
  22. data/lib/xqsr3/extensions/enumerable/detect_map.rb +41 -41
  23. data/lib/xqsr3/extensions/enumerable/unique.rb +32 -31
  24. data/lib/xqsr3/extensions/hash/deep_transform.rb +1 -1
  25. data/lib/xqsr3/extensions/hash/except.rb +16 -16
  26. data/lib/xqsr3/extensions/hash/has_match.rb +10 -10
  27. data/lib/xqsr3/extensions/hash/match.rb +10 -10
  28. data/lib/xqsr3/extensions/hash/slice.rb +11 -11
  29. data/lib/xqsr3/extensions/hash.rb +1 -1
  30. data/lib/xqsr3/extensions/integer/to_s_grp.rb +118 -0
  31. data/lib/xqsr3/extensions/integer.rb +3 -0
  32. data/lib/xqsr3/extensions/io/writelines.rb +34 -34
  33. data/lib/xqsr3/extensions/kernel/integer.rb +26 -26
  34. data/lib/xqsr3/extensions/kernel/raise_with_options.rb +15 -14
  35. data/lib/xqsr3/extensions/kernel.rb +1 -0
  36. data/lib/xqsr3/extensions/string/ends_with.rb +1 -1
  37. data/lib/xqsr3/extensions/string/map_option_string.rb +4 -5
  38. data/lib/xqsr3/extensions/string/nil_if_empty.rb +1 -1
  39. data/lib/xqsr3/extensions/string/nil_if_whitespace.rb +1 -1
  40. data/lib/xqsr3/extensions/string/quote_if.rb +1 -2
  41. data/lib/xqsr3/extensions/string/starts_with.rb +1 -1
  42. data/lib/xqsr3/extensions/string/to_bool.rb +8 -9
  43. data/lib/xqsr3/extensions/string/to_symbol.rb +1 -1
  44. data/lib/xqsr3/extensions/string/truncate.rb +1 -2
  45. data/lib/xqsr3/extensions/test/unit/assert_eql.rb +7 -7
  46. data/lib/xqsr3/extensions/test/unit/assert_false.rb +6 -7
  47. data/lib/xqsr3/extensions/test/unit/assert_not.rb +6 -7
  48. data/lib/xqsr3/extensions/test/unit/assert_not_eql.rb +7 -7
  49. data/lib/xqsr3/extensions/test/unit/assert_raise_with_message.rb +61 -62
  50. data/lib/xqsr3/extensions/test/unit/assert_subclass_of.rb +7 -8
  51. data/lib/xqsr3/extensions/test/unit/assert_superclass_of.rb +7 -8
  52. data/lib/xqsr3/extensions/test/unit/assert_true.rb +6 -7
  53. data/lib/xqsr3/extensions/test/unit/assert_type_has_instance_methods.rb +36 -38
  54. data/lib/xqsr3/extensions.rb +5 -5
  55. data/lib/xqsr3/hash_utilities/deep_transform.rb +71 -71
  56. data/lib/xqsr3/hash_utilities/key_matching.rb +82 -82
  57. data/lib/xqsr3/hash_utilities.rb +3 -3
  58. data/lib/xqsr3/internal_/test_unit_version_.rb +130 -88
  59. data/lib/xqsr3/io/writelines.rb +125 -125
  60. data/lib/xqsr3/quality/parameter_checking.rb +452 -453
  61. data/lib/xqsr3/quality.rb +2 -2
  62. data/lib/xqsr3/string_utilities/ends_with.rb +64 -64
  63. data/lib/xqsr3/string_utilities/nil_if_empty.rb +33 -34
  64. data/lib/xqsr3/string_utilities/nil_if_whitespace.rb +35 -35
  65. data/lib/xqsr3/string_utilities/quote_if.rb +55 -56
  66. data/lib/xqsr3/string_utilities/starts_with.rb +64 -64
  67. data/lib/xqsr3/string_utilities/to_symbol.rb +80 -80
  68. data/lib/xqsr3/string_utilities/truncate.rb +60 -61
  69. data/lib/xqsr3/string_utilities.rb +8 -8
  70. data/lib/xqsr3/version.rb +19 -20
  71. data/test/performance/frequency_map.rb +13 -27
  72. data/test/scratch/test_assert_raise_with_message.rb +12 -13
  73. data/test/unit/array_utilities/tc_join_with_or.rb +140 -142
  74. data/test/unit/command_line_utilities/tc_map_option_string.rb +18 -18
  75. data/test/unit/containers/tc_frequency_map.rb +607 -554
  76. data/test/unit/containers/tc_multi_map.rb +573 -522
  77. data/test/unit/conversion/tc_integer_parser.rb +73 -73
  78. data/test/unit/conversion/tc_to_bool.rb +26 -26
  79. data/test/unit/diagnostics/exceptions/tc_with_cause.rb +165 -165
  80. data/test/unit/diagnostics/tc_exception_utilities.rb +156 -156
  81. data/test/unit/extensions/enumerable/tc_collect_with_index.rb +14 -14
  82. data/test/unit/extensions/enumerable/tc_detect_map.rb +20 -20
  83. data/test/unit/extensions/enumerable/tc_unique.rb +34 -34
  84. data/test/unit/extensions/hash/tc_deep_transform.rb +22 -22
  85. data/test/unit/extensions/hash/tc_except.rb +28 -28
  86. data/test/unit/extensions/hash/tc_hash.rb +1 -1
  87. data/test/unit/extensions/hash/tc_slice.rb +14 -14
  88. data/test/unit/extensions/integer/tc_to_s_grp.rb +60 -0
  89. data/test/unit/extensions/integer/ts_all.rb +12 -0
  90. data/test/unit/extensions/io/tc_writelines.rb +77 -77
  91. data/test/unit/extensions/kernel/tc_integer.rb +75 -75
  92. data/test/unit/extensions/kernel/tc_raise_with_options.rb +155 -155
  93. data/test/unit/extensions/object/tc_inspect.rb +51 -51
  94. data/test/unit/extensions/string/tc_bool.tb +24 -24
  95. data/test/unit/extensions/string/tc_ends_with.rb +53 -53
  96. data/test/unit/extensions/string/tc_map_option_string.rb +15 -15
  97. data/test/unit/extensions/string/tc_nil_if_empty.rb +8 -8
  98. data/test/unit/extensions/string/tc_nil_if_whitespace.rb +8 -8
  99. data/test/unit/extensions/string/tc_quote_if.rb +18 -18
  100. data/test/unit/extensions/string/tc_starts_with.rb +53 -53
  101. data/test/unit/extensions/string/tc_to_symbol.rb +26 -26
  102. data/test/unit/extensions/string/tc_truncate.rb +18 -18
  103. data/test/unit/extensions/test/unit/tc_assert_raise_with_message.rb +16 -16
  104. data/test/unit/extensions/test/unit/tc_assert_subclass_of.rb +9 -9
  105. data/test/unit/extensions/test/unit/tc_assert_superclass_of.rb +9 -9
  106. data/test/unit/hash_utilities/tc_has_match.rb +70 -70
  107. data/test/unit/hash_utilities/tc_match.rb +83 -83
  108. data/test/unit/io/tc_writelines.rb +106 -108
  109. data/test/unit/quality/tc_parameter_checking.rb +390 -390
  110. data/test/unit/string_utilities/tc_truncate.rb +28 -28
  111. data/test/unit/tc_version.rb +15 -15
  112. metadata +6 -2
data/lib/xqsr3/quality.rb CHANGED
@@ -1,10 +1,10 @@
1
1
 
2
2
  %w{
3
3
 
4
- parameter_checking
4
+ parameter_checking
5
5
  }.each do |name|
6
6
 
7
- require File.join(File.dirname(__FILE__), 'quality', name)
7
+ require File.join(File.dirname(__FILE__), 'quality', name)
8
8
  end
9
9
 
10
10
 
@@ -1,17 +1,17 @@
1
1
 
2
2
  # ######################################################################## #
3
- # File: lib/xqsr3/string_utilities/ends_with.rb
3
+ # File: lib/xqsr3/string_utilities/ends_with.rb
4
4
  #
5
- # Purpose: Definition of the ::Xqsr3::StringUtilities::EndsWith
6
- # module
5
+ # Purpose: Definition of the ::Xqsr3::StringUtilities::EndsWith module
7
6
  #
8
- # Created: 13th April 2016
9
- # Updated: 15th April 2019
7
+ # Created: 13th April 2016
8
+ # Updated: 29th March 2024
10
9
  #
11
- # Home: http://github.com/synesissoftware/xqsr3
10
+ # Home: http://github.com/synesissoftware/xqsr3
12
11
  #
13
- # Author: Matthew Wilson
12
+ # Author: Matthew Wilson
14
13
  #
14
+ # Copyright (c) 2019-2024, Matthew Wilson and Synesis Information Systems
15
15
  # Copyright (c) 2016-2019, Matthew Wilson and Synesis Software
16
16
  # All rights reserved.
17
17
  #
@@ -26,7 +26,7 @@
26
26
  # notice, this list of conditions and the following disclaimer in the
27
27
  # documentation and/or other materials provided with the distribution.
28
28
  #
29
- # * Neither the names of the copyright holder nor the names of its
29
+ # * Neither the names of the copyright holders nor the names of its
30
30
  # contributors may be used to endorse or promote products derived from
31
31
  # this software without specific prior written permission.
32
32
  #
@@ -58,84 +58,84 @@ module StringUtilities
58
58
  # methods
59
59
  module EndsWith
60
60
 
61
- private
62
- # @!visibility private
63
- module EndsWith_Helper_ # :nodoc: all
61
+ private
62
+ # @!visibility private
63
+ module EndsWith_Helper_ # :nodoc: all
64
64
 
65
- def self.string_ends_with_helper_ s, prefix # :nodoc:
65
+ def self.string_ends_with_helper_ s, prefix # :nodoc:
66
66
 
67
- if prefix.nil? || prefix.empty?
67
+ if prefix.nil? || prefix.empty?
68
68
 
69
- return ''
70
- elsif prefix.size < s.size
69
+ return ''
70
+ elsif prefix.size < s.size
71
71
 
72
- return prefix if s[(s.size - prefix.size) ... s.size] == prefix
73
- elsif prefix.size == s.size
72
+ return prefix if s[(s.size - prefix.size) ... s.size] == prefix
73
+ elsif prefix.size == s.size
74
74
 
75
- return prefix if prefix == s
76
- else
75
+ return prefix if prefix == s
76
+ else
77
77
 
78
- nil
79
- end
78
+ nil
79
+ end
80
80
 
81
- nil
82
- end
81
+ nil
82
+ end
83
83
 
84
- def self.string_ends_with_array_ s, args # :nodoc:
84
+ def self.string_ends_with_array_ s, args # :nodoc:
85
85
 
86
- return '' if args.empty?
86
+ return '' if args.empty?
87
87
 
88
- args.each do |prefix|
88
+ args.each do |prefix|
89
89
 
90
- case prefix
91
- when ::NilClass
90
+ case prefix
91
+ when ::NilClass
92
92
 
93
- return ''
94
- when ::String
93
+ return ''
94
+ when ::String
95
95
 
96
- r = self.string_ends_with_helper_ s, prefix
96
+ r = self.string_ends_with_helper_ s, prefix
97
97
 
98
- return r if r
99
- else
98
+ return r if r
99
+ else
100
100
 
101
- if prefix.respond_to? :to_str
101
+ if prefix.respond_to? :to_str
102
102
 
103
- return self.string_ends_with_helper_ s.prefix.to_str
104
- end
103
+ return self.string_ends_with_helper_ s.prefix.to_str
104
+ end
105
105
 
106
- raise TypeError, "ends_with? can be passed instances of #{::String}, or nil, or types that respond to to_str"
107
- end
108
- end
106
+ raise TypeError, "ends_with? can be passed instances of #{::String}, or nil, or types that respond to to_str"
107
+ end
108
+ end
109
109
 
110
- return nil
111
- end
112
- end
113
- public
110
+ return nil
111
+ end
112
+ end
113
+ public
114
114
 
115
- # Reports on whether a string +s+ ends with a given prefix or set of
116
- # prefixes (+args+)
117
- #
118
- # === Signature
119
- #
120
- # * *Parameters:*
121
- # - +s+ (String) The string to be evaluated
122
- # - +args+ 0+ arguments against which +s+ will be evaluated
123
- def self.string_ends_with? s, *args
115
+ # Reports on whether a string +s+ ends with a given prefix or set of
116
+ # prefixes (+args+)
117
+ #
118
+ # === Signature
119
+ #
120
+ # * *Parameters:*
121
+ # - +s+ (String) The string to be evaluated
122
+ # - +args+ 0+ arguments against which +s+ will be evaluated
123
+ def self.string_ends_with? s, *args
124
124
 
125
- EndsWith_Helper_.string_ends_with_array_ s, args
126
- end
125
+ EndsWith_Helper_.string_ends_with_array_ s, args
126
+ end
127
127
 
128
- # Reports on whether the instance ends with a given prefix or set of
129
- # prefixes (+args+)
130
- #
131
- # === Signature
132
- #
133
- # * *Parameters:*
134
- # - +args+ 0+ arguments against which the instance will be evaluated
135
- def ends_with? *args
128
+ # Reports on whether the instance ends with a given prefix or set of
129
+ # prefixes (+args+)
130
+ #
131
+ # === Signature
132
+ #
133
+ # * *Parameters:*
134
+ # - +args+ 0+ arguments against which the instance will be evaluated
135
+ def ends_with? *args
136
136
 
137
- EndsWith_Helper_.string_ends_with_array_ self, args
138
- end
137
+ EndsWith_Helper_.string_ends_with_array_ self, args
138
+ end
139
139
  end # module EndsWith
140
140
 
141
141
  end # module StringUtilities
@@ -1,17 +1,17 @@
1
1
 
2
2
  # ######################################################################## #
3
- # File: lib/xqsr3/string_utilities/nil_if_empty.rb
3
+ # File: lib/xqsr3/string_utilities/nil_if_empty.rb
4
4
  #
5
- # Purpose: Definition of the ::Xqsr3::StringUtilities::NilIfEmpty
6
- # module
5
+ # Purpose: Definition of the ::Xqsr3::StringUtilities::NilIfEmpty module
7
6
  #
8
- # Created: 25th January 2018
9
- # Updated: 15th April 2019
7
+ # Created: 25th January 2018
8
+ # Updated: 29th March 2024
10
9
  #
11
- # Home: http://github.com/synesissoftware/xqsr3
10
+ # Home: http://github.com/synesissoftware/xqsr3
12
11
  #
13
- # Author: Matthew Wilson
12
+ # Author: Matthew Wilson
14
13
  #
14
+ # Copyright (c) 2019-2024, Matthew Wilson and Synesis Information Systems
15
15
  # Copyright (c) 2018-2019, Matthew Wilson and Synesis Software
16
16
  # All rights reserved.
17
17
  #
@@ -26,7 +26,7 @@
26
26
  # notice, this list of conditions and the following disclaimer in the
27
27
  # documentation and/or other materials provided with the distribution.
28
28
  #
29
- # * Neither the names of the copyright holder nor the names of its
29
+ # * Neither the names of the copyright holders nor the names of its
30
30
  # contributors may be used to endorse or promote products derived from
31
31
  # this software without specific prior written permission.
32
32
  #
@@ -58,38 +58,38 @@ module StringUtilities
58
58
  # #nil_if_empty methods
59
59
  module NilIfEmpty
60
60
 
61
- private
62
- # @!visibility private
63
- module NilIfEmpty_Helper_ # :nodoc: all
61
+ private
62
+ # @!visibility private
63
+ module NilIfEmpty_Helper_ # :nodoc: all
64
64
 
65
- def self.string_nil_if_empty_array_ s # :nodoc:
65
+ def self.string_nil_if_empty_array_ s # :nodoc:
66
66
 
67
- return s if s && !s.empty?
67
+ return s if s && !s.empty?
68
68
 
69
- nil
70
- end
71
- end
72
- public
69
+ nil
70
+ end
71
+ end
72
+ public
73
73
 
74
- # Returns +nil+ if the given string is empty, otherwise returning the
75
- # given string
76
- #
77
- # === Signature
78
- #
79
- # * *Parameters:*
80
- #
81
- # * *Required parameters*:
82
- # - +s+ (String) The string to be evaluated
83
- def self.string_nil_if_empty s
74
+ # Returns +nil+ if the given string is empty, otherwise returning the
75
+ # given string
76
+ #
77
+ # === Signature
78
+ #
79
+ # * *Parameters:*
80
+ #
81
+ # * *Required parameters*:
82
+ # - +s+ (String) The string to be evaluated
83
+ def self.string_nil_if_empty s
84
84
 
85
- NilIfEmpty_Helper_.string_nil_if_empty_array_ s
86
- end
85
+ NilIfEmpty_Helper_.string_nil_if_empty_array_ s
86
+ end
87
87
 
88
- # Returns +nil+ if the instance is empty, otherwise returning self
89
- def nil_if_empty
88
+ # Returns +nil+ if the instance is empty, otherwise returning self
89
+ def nil_if_empty
90
90
 
91
- NilIfEmpty_Helper_.string_nil_if_empty_array_ self
92
- end
91
+ NilIfEmpty_Helper_.string_nil_if_empty_array_ self
92
+ end
93
93
  end # module NilIfEmpty
94
94
 
95
95
  end # module StringUtilities
@@ -97,4 +97,3 @@ end # module Xqsr3
97
97
 
98
98
  # ############################## end of file ############################# #
99
99
 
100
-
@@ -1,17 +1,18 @@
1
1
 
2
2
  # ######################################################################## #
3
- # File: lib/xqsr3/string_utilities/nil_if_whitespace.rb
3
+ # File: lib/xqsr3/string_utilities/nil_if_whitespace.rb
4
4
  #
5
- # Purpose: Definition of the ::Xqsr3::StringUtilities::NilIfWhitespace
6
- # module
5
+ # Purpose: Definition of the ::Xqsr3::StringUtilities::NilIfWhitespace
6
+ # module
7
7
  #
8
- # Created: 25th January 2018
9
- # Updated: 15th April 2019
8
+ # Created: 25th January 2018
9
+ # Updated: 29th March 2024
10
10
  #
11
- # Home: http://github.com/synesissoftware/xqsr3
11
+ # Home: http://github.com/synesissoftware/xqsr3
12
12
  #
13
- # Author: Matthew Wilson
13
+ # Author: Matthew Wilson
14
14
  #
15
+ # Copyright (c) 2019-2024, Matthew Wilson and Synesis Information Systems
15
16
  # Copyright (c) 2018-2019, Matthew Wilson and Synesis Software
16
17
  # All rights reserved.
17
18
  #
@@ -26,7 +27,7 @@
26
27
  # notice, this list of conditions and the following disclaimer in the
27
28
  # documentation and/or other materials provided with the distribution.
28
29
  #
29
- # * Neither the names of the copyright holder nor the names of its
30
+ # * Neither the names of the copyright holders nor the names of its
30
31
  # contributors may be used to endorse or promote products derived from
31
32
  # this software without specific prior written permission.
32
33
  #
@@ -58,39 +59,39 @@ module StringUtilities
58
59
  # #nil_if_whitespace methods
59
60
  module NilIfWhitespace
60
61
 
61
- private
62
- # @!visibility private
63
- module NilIfWhitespace_Helper_ # :nodoc: all
62
+ private
63
+ # @!visibility private
64
+ module NilIfWhitespace_Helper_ # :nodoc: all
64
65
 
65
- def self.string_nil_if_whitespace_array_ s # :nodoc:
66
+ def self.string_nil_if_whitespace_array_ s # :nodoc:
66
67
 
67
- return nil if s.strip.empty?
68
+ return nil if s.strip.empty?
68
69
 
69
- s
70
- end
71
- end
72
- public
70
+ s
71
+ end
72
+ end
73
+ public
73
74
 
74
- # Returns +nil+ if the given string is empty or contains only whitespace,
75
- # otherwise returning the given string
76
- #
77
- # === Signature
78
- #
79
- # * *Parameters:*
80
- #
81
- # * *Required parameters*:
82
- # - +s+ (String) The string to be evaluated
83
- def self.string_nil_if_whitespace s
75
+ # Returns +nil+ if the given string is empty or contains only whitespace,
76
+ # otherwise returning the given string
77
+ #
78
+ # === Signature
79
+ #
80
+ # * *Parameters:*
81
+ #
82
+ # * *Required parameters*:
83
+ # - +s+ (String) The string to be evaluated
84
+ def self.string_nil_if_whitespace s
84
85
 
85
- NilIfWhitespace_Helper_.string_nil_if_whitespace_array_ s
86
- end
86
+ NilIfWhitespace_Helper_.string_nil_if_whitespace_array_ s
87
+ end
87
88
 
88
- # Returns +nil+ if the instance is empty or contains only whitespace,
89
- # otherwise returning self
90
- def nil_if_whitespace
89
+ # Returns +nil+ if the instance is empty or contains only whitespace,
90
+ # otherwise returning self
91
+ def nil_if_whitespace
91
92
 
92
- NilIfWhitespace_Helper_.string_nil_if_whitespace_array_ self
93
- end
93
+ NilIfWhitespace_Helper_.string_nil_if_whitespace_array_ self
94
+ end
94
95
  end # module NilIfWhitespace
95
96
 
96
97
  end # module StringUtilities
@@ -98,4 +99,3 @@ end # module Xqsr3
98
99
 
99
100
  # ############################## end of file ############################# #
100
101
 
101
-
@@ -1,17 +1,17 @@
1
1
 
2
2
  # ######################################################################## #
3
- # File: lib/xqsr3/string_utilities/quote_if.rb
3
+ # File: lib/xqsr3/string_utilities/quote_if.rb
4
4
  #
5
- # Purpose: Definition of the ::Xqsr3::StringUtilities::QuoteIf
6
- # module
5
+ # Purpose: Definition of the ::Xqsr3::StringUtilities::QuoteIf module
7
6
  #
8
- # Created: 3rd June 2017
9
- # Updated: 15th April 2019
7
+ # Created: 3rd June 2017
8
+ # Updated: 29th March 2024
10
9
  #
11
- # Home: http://github.com/synesissoftware/xqsr3
10
+ # Home: http://github.com/synesissoftware/xqsr3
12
11
  #
13
- # Author: Matthew Wilson
12
+ # Author: Matthew Wilson
14
13
  #
14
+ # Copyright (c) 2019-2024, Matthew Wilson and Synesis Information Systems
15
15
  # Copyright (c) 2017-2019, Matthew Wilson and Synesis Software
16
16
  # All rights reserved.
17
17
  #
@@ -26,7 +26,7 @@
26
26
  # notice, this list of conditions and the following disclaimer in the
27
27
  # documentation and/or other materials provided with the distribution.
28
28
  #
29
- # * Neither the names of the copyright holder nor the names of its
29
+ # * Neither the names of the copyright holders nor the names of its
30
30
  # contributors may be used to endorse or promote products derived from
31
31
  # this software without specific prior written permission.
32
32
  #
@@ -57,67 +57,67 @@ module StringUtilities
57
57
  # +include+-able module that provides ::quote_if and #quote_if methods
58
58
  module QuoteIf
59
59
 
60
- private
61
- # @!visibility private
62
- module QuoteIf_Helper_ # :nodoc: all
60
+ private
61
+ # @!visibility private
62
+ module QuoteIf_Helper_ # :nodoc: all
63
63
 
64
- def self.string_quote_if_array_ s, options # :nodoc:
64
+ def self.string_quote_if_array_ s, options # :nodoc:
65
65
 
66
- s = s.to_s unless String === s
66
+ s = s.to_s unless String === s
67
67
 
68
- quotes = options[:quotes] || [ '"', '"' ]
69
- quotes = [ quotes, quotes ] if String === quotes
68
+ quotes = options[:quotes] || [ '"', '"' ]
69
+ quotes = [ quotes, quotes ] if String === quotes
70
70
 
71
- quotables = options[:quotables] || /\s/
71
+ quotables = options[:quotables] || /\s/
72
72
 
73
- case quotables
74
- when ::String
73
+ case quotables
74
+ when ::String
75
75
 
76
- return s unless s.include? quotables
77
- when ::Array
76
+ return s unless s.include? quotables
77
+ when ::Array
78
78
 
79
- return s unless quotables.any? { |quotable| s.include? quotable }
80
- when ::Regexp
79
+ return s unless quotables.any? { |quotable| s.include? quotable }
80
+ when ::Regexp
81
81
 
82
- return s unless s =~ quotables
83
- else
82
+ return s unless s =~ quotables
83
+ else
84
84
 
85
- raise ArgumentError, "Invalid type (#{quotables.class}) specified for quotables parameter"
86
- end
85
+ raise ArgumentError, "Invalid type (#{quotables.class}) specified for quotables parameter"
86
+ end
87
87
 
88
- return quotes[0] + s + quotes[1]
89
- end
90
- end
91
- public
88
+ return quotes[0] + s + quotes[1]
89
+ end
90
+ end
91
+ public
92
92
 
93
- # Converts a string to a quoted form if necessary
94
- #
95
- # === Signature
96
- #
97
- # * *Parameters:*
98
- #
99
- # * *Required parameters*:
100
- # - +s+ (String) The string to be evaluated
101
- #
102
- # * *Options parameters*:
103
- # - +options+ (Hash) Options that control the behaviour of the method
104
- #
105
- # * *Options:*
106
- #
107
- # - +:quotes+ (String, Array) A string that is used as the opening and closing quotes, or an array whose first two elements are used as the opening and closing quotes. Defaults to +'"'+
108
- # - +:quotables+ (String, Array, Regexp) A string representing the quotable character, or an array containing the quotable characters, or a regular expression that determines by match whether the string should be quoted. Defaults to the regular expression +/\s/+
109
- def self.quote_if s, **options
93
+ # Converts a string to a quoted form if necessary
94
+ #
95
+ # === Signature
96
+ #
97
+ # * *Parameters:*
98
+ #
99
+ # * *Required parameters*:
100
+ # - +s+ (String) The string to be evaluated
101
+ #
102
+ # * *Options parameters*:
103
+ # - +options+ (Hash) Options that control the behaviour of the method
104
+ #
105
+ # * *Options:*
106
+ #
107
+ # - +:quotes+ (String, Array) A string that is used as the opening and closing quotes, or an array whose first two elements are used as the opening and closing quotes. Defaults to +'"'+
108
+ # - +:quotables+ (String, Array, Regexp) A string representing the quotable character, or an array containing the quotable characters, or a regular expression that determines by match whether the string should be quoted. Defaults to the regular expression +/\s/+
109
+ def self.quote_if s, **options
110
110
 
111
- QuoteIf_Helper_.string_quote_if_array_ s, options
112
- end
111
+ QuoteIf_Helper_.string_quote_if_array_ s, options
112
+ end
113
113
 
114
- # Converts the instance to a quoted form if necessary
115
- #
116
- # See Xqsr3::StringUtilities::QuoteIf::quite_if() for options
117
- def quote_if **options
114
+ # Converts the instance to a quoted form if necessary
115
+ #
116
+ # See Xqsr3::StringUtilities::QuoteIf::quite_if() for options
117
+ def quote_if **options
118
118
 
119
- QuoteIf_Helper_.string_quote_if_array_ self, options
120
- end
119
+ QuoteIf_Helper_.string_quote_if_array_ self, options
120
+ end
121
121
  end # module QuoteIf
122
122
 
123
123
  end # module StringUtilities
@@ -125,4 +125,3 @@ end # module Xqsr3
125
125
 
126
126
  # ############################## end of file ############################# #
127
127
 
128
-