From 59de960813431f3559e9652d3508d8f6f9592913 Mon Sep 17 00:00:00 2001 From: Takafumi Arakaki Date: Mon, 16 Dec 2019 09:25:05 -0800 Subject: [PATCH] Add Tables interface to RowIterator (#126) --- src/fallbacks.jl | 6 ++++++ test/runtests.jl | 6 ++++++ 2 files changed, 12 insertions(+) diff --git a/src/fallbacks.jl b/src/fallbacks.jl index cfe094b..ca2945e 100644 --- a/src/fallbacks.jl +++ b/src/fallbacks.jl @@ -52,6 +52,12 @@ struct RowIterator{T} end Base.eltype(x::RowIterator{T}) where {T} = ColumnsRow{T} Base.length(x::RowIterator) = x.len +istable(::Type{<:RowIterator}) = true +rowaccess(::Type{<:RowIterator}) = true +rows(x::RowIterator) = x +columnaccess(::Type{<:RowIterator{T}}) where T = columnaccess(T) +columns(x::RowIterator) = x.columns +materializer(x::RowIterator) = materializer(x.columns) schema(x::RowIterator) = schema(x.columns) function Base.iterate(rows::RowIterator, st=1) diff --git a/test/runtests.jl b/test/runtests.jl index 5c76605..fda6e18 100644 --- a/test/runtests.jl +++ b/test/runtests.jl @@ -74,6 +74,12 @@ using Test, Tables, TableTraits, DataValues, QueryOperators, IteratorInterfaceEx @test Tables.schema(rows) == Tables.Schema((:a, :b), (Int, Int)) row = first(rows) @test row.a == 1 + @test Tables.istable(rows) + @test Tables.rowaccess(rows) + @test Tables.rows(rows) === rows + @test Tables.columnaccess(rows) + @test Tables.columns(rows) === nt + @test Tables.materializer(rows) === Tables.materializer(nt) @test Tables.sym(1) === 1 @test Tables.sym("hey") == :hey