node_mutation 1.8.0 → 1.8.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +4 -0
- data/Gemfile.lock +1 -1
- data/lib/node_mutation/parser_adapter.rb +5 -3
- data/lib/node_mutation/version.rb +1 -1
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e468a837b5ab1417a0675f92ae5848b87b66cfe9605a3ce56142f58859ba7036
|
4
|
+
data.tar.gz: 898a9e080a406c84027b3ea84bf76826c8deb2ea36c406a767774c7610809dea
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 40498dd85e42e77268ed72851692c906221e2ea167765867155a30c0e992b6e4a8c4e89cfee7295743dd94f6d3405dcaeabeb845be3a3dc1a7cb473983ba6bf2
|
7
|
+
data.tar.gz: f99ba22c58428b002285e9dd6e959b993725216265457d2df8a4b7fd934537861ca04ce6955bedc8dea0fb29efb0174e44a53a7ae6e07c9aad2e68daa2dab154
|
data/CHANGELOG.md
CHANGED
data/Gemfile.lock
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
+
INDEX_REGEXP = /\A-?\d+\z/
|
4
|
+
|
3
5
|
class NodeMutation::ParserAdapter < NodeMutation::Adapter
|
4
6
|
def get_source(node)
|
5
7
|
if node.is_a?(Array)
|
@@ -60,7 +62,7 @@ class NodeMutation::ParserAdapter < NodeMutation::Adapter
|
|
60
62
|
direct_child_name, nested_child_name = child_name.to_s.split('.', 2)
|
61
63
|
|
62
64
|
if node.is_a?(Array)
|
63
|
-
if direct_child_name =~
|
65
|
+
if direct_child_name =~ INDEX_REGEXP
|
64
66
|
child_node = node[direct_child_name.to_i]
|
65
67
|
raise NodeMutation::MethodNotSupported, "#{direct_child_name} is not supported for #{get_source(node)}" unless child_node
|
66
68
|
return child_node_range(child_node, nested_child_name) if nested_child_name
|
@@ -163,8 +165,8 @@ class NodeMutation::ParserAdapter < NodeMutation::Adapter
|
|
163
165
|
direct_child_name, nested_child_name = child_name.to_s.split('.', 2)
|
164
166
|
|
165
167
|
if node.is_a?(Array)
|
166
|
-
if direct_child_name =~
|
167
|
-
child_node = node[direct_child_name.to_i
|
168
|
+
if direct_child_name =~ INDEX_REGEXP
|
169
|
+
child_node = node[direct_child_name.to_i]
|
168
170
|
raise NodeMutation::MethodNotSupported, "#{direct_child_name} is not supported for #{get_source(node)}" unless child_node
|
169
171
|
return child_node_by_name(child_node, nested_child_name) if nested_child_name
|
170
172
|
return child_node
|