Skip to content

Commit 3049131

Browse files
authored
GH-48610: [Ruby] Add FixedSizeListArray glue (#48609)
### Rationale for this change When testing ListSliceOptions I noticed that some glue were missing from the Ruby code. ### What changes are included in this PR? This adds the `FixedSizeListArrayBuilder.build` method in Ruby. ### Are these changes tested? Yes. ### Are there any user-facing changes? This makes it easier to create `FixedSizeListArray` objects in Ruby. * GitHub Issue: #48610 Authored-by: Sten Larsson <[email protected]> Signed-off-by: Sutou Kouhei <[email protected]>
1 parent d89c14b commit 3049131

File tree

3 files changed

+61
-0
lines changed

3 files changed

+61
-0
lines changed
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
# Licensed to the Apache Software Foundation (ASF) under one
2+
# or more contributor license agreements. See the NOTICE file
3+
# distributed with this work for additional information
4+
# regarding copyright ownership. The ASF licenses this file
5+
# to you under the Apache License, Version 2.0 (the
6+
# "License"); you may not use this file except in compliance
7+
# with the License. You may obtain a copy of the License at
8+
#
9+
# http://www.apache.org/licenses/LICENSE-2.0
10+
#
11+
# Unless required by applicable law or agreed to in writing,
12+
# software distributed under the License is distributed on an
13+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14+
# KIND, either express or implied. See the License for the
15+
# specific language governing permissions and limitations
16+
# under the License.
17+
18+
module Arrow
19+
class FixedSizeListArrayBuilder
20+
class << self
21+
def build(data_type, values)
22+
builder = new(data_type)
23+
builder.build(values)
24+
end
25+
end
26+
27+
prepend ListValuesAppendable
28+
end
29+
end

ruby/red-arrow/lib/arrow/libraries.rb

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -69,6 +69,7 @@
6969
require_relative "file-system"
7070
require_relative "fixed-size-binary-array"
7171
require_relative "fixed-size-binary-array-builder"
72+
require_relative "fixed-size-list-array-builder"
7273
require_relative "function"
7374
require_relative "group"
7475
require_relative "half-float"
Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
# Licensed to the Apache Software Foundation (ASF) under one
2+
# or more contributor license agreements. See the NOTICE file
3+
# distributed with this work for additional information
4+
# regarding copyright ownership. The ASF licenses this file
5+
# to you under the Apache License, Version 2.0 (the
6+
# "License"); you may not use this file except in compliance
7+
# with the License. You may obtain a copy of the License at
8+
#
9+
# http://www.apache.org/licenses/LICENSE-2.0
10+
#
11+
# Unless required by applicable law or agreed to in writing,
12+
# software distributed under the License is distributed on an
13+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14+
# KIND, either express or implied. See the License for the
15+
# specific language governing permissions and limitations
16+
# under the License.
17+
18+
class FixedSizeListArrayTest < Test::Unit::TestCase
19+
sub_test_case(".new") do
20+
test("build") do
21+
data_type = [:fixed_size_list, :int8, 2]
22+
values = [
23+
[1, 2],
24+
[3, 4],
25+
nil,
26+
]
27+
array = Arrow::FixedSizeListArray.new(data_type, values)
28+
assert_equal(values, array.map { |v| v&.to_a })
29+
end
30+
end
31+
end

0 commit comments

Comments
 (0)