]> git.proxmox.com Git - ceph.git/blame - ceph/src/arrow/ruby/red-arrow/lib/arrow/generic-filterable.rb
import quincy 17.2.0
[ceph.git] / ceph / src / arrow / ruby / red-arrow / lib / arrow / generic-filterable.rb
CommitLineData
1d09f67e
TL
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
18module Arrow
19 module GenericFilterable
20 class << self
21 def included(base)
22 base.__send__(:alias_method, :filter_raw, :filter)
23 base.__send__(:alias_method, :filter, :filter_generic)
24 end
25 end
26
27 def filter_generic(filter, options=nil)
28 case filter
29 when ::Array
30 filter_raw(BooleanArray.new(filter), options)
31 when ChunkedArray
32 if respond_to?(:filter_chunked_array)
33 filter_chunked_array(filter, options)
34 else
35 # TODO: Implement this in C++
36 filter_raw(filter.pack, options)
37 end
38 else
39 filter_raw(filter, options)
40 end
41 end
42 end
43end