From 71ebcbd7c610feeae2489218f281d8a21fd33f49 Mon Sep 17 00:00:00 2001 From: Maarten Pronk Date: Mon, 16 Dec 2024 18:29:11 +0100 Subject: [PATCH] Add generic setfield fallbacks. --- Project.toml | 2 +- src/ogr/feature.jl | 16 ++++++++++++++++ src/types.jl | 12 ++++++++++++ test/Project.toml | 1 + test/test_convert.jl | 8 ++++++++ test/test_feature.jl | 11 +++++++++++ 6 files changed, 49 insertions(+), 1 deletion(-) diff --git a/Project.toml b/Project.toml index 5b821b3a..fec4fdbf 100644 --- a/Project.toml +++ b/Project.toml @@ -3,7 +3,7 @@ uuid = "c9ce4bd3-c3d5-55b8-8973-c0e20141b8c3" keywords = ["GDAL", "IO"] license = "MIT" desc = "A high level API for GDAL - Geospatial Data Abstraction Library" -version = "0.10.5" +version = "0.10.6" [deps] CEnum = "fa961155-64e5-5f13-b03f-caf6b980ea82" diff --git a/src/ogr/feature.jl b/src/ogr/feature.jl index 5c7973c6..56f52ffa 100644 --- a/src/ogr/feature.jl +++ b/src/ogr/feature.jl @@ -625,6 +625,22 @@ function setfield!( return feature end +function setfield!( + feature::AbstractFeature, + i::Integer, + value::Integer, +)::AbstractFeature + return setfield!(feature, i, convert(Int64, value)) +end + +function setfield!( + feature::AbstractFeature, + i::Integer, + value::Real, +)::AbstractFeature + return setfield!(feature, i, convert(Float64, value)) +end + function setfield!( feature::AbstractFeature, i::Integer, diff --git a/src/types.jl b/src/types.jl index 38e85909..aba58abe 100644 --- a/src/types.jl +++ b/src/types.jl @@ -374,6 +374,14 @@ function Base.convert(og::Type{OGRFieldType}, ::Type{<:Enum{T}}) where {T} return Base.convert(og, T) end +function Base.convert(::Type{OGRFieldType}, ::Type{<:Real}) + return OFTReal +end + +function Base.convert(::Type{OGRFieldType}, ::Type{<:Integer}) + return OFTInteger64 +end + @convert( OGRFieldSubType::GDAL.OGRFieldSubType, OFSTNone::GDAL.OFSTNone, @@ -420,6 +428,10 @@ function Base.convert(og::Type{OGRFieldSubType}, ::Type{<:Enum{T}}) where {T} return Base.convert(og, T) end +function Base.convert(::Type{OGRFieldSubType}, ::Type{<:Real}) + return OFSTNone +end + @convert( OGRJustification::GDAL.OGRJustification, OJUndefined::GDAL.OJUndefined, diff --git a/test/Project.toml b/test/Project.toml index b23afeb8..994a2807 100644 --- a/test/Project.toml +++ b/test/Project.toml @@ -6,6 +6,7 @@ DiskArrays = "3c3547ce-8d99-4f5e-a174-61eb10b00ae3" Documenter = "e30172f5-a6a5-5a46-863b-614d45cd2de4" Downloads = "f43a241f-c20a-4ad4-852c-f6b1247861c6" Extents = "411431e0-e8b7-467b-b5e0-f676ba4f2910" +FixedPointNumbers = "53c48c17-4a7d-5ca2-90c5-79b7896eea93" GDAL = "add2ef01-049f-52c4-9ee2-e494f65e021a" GeoFormatTypes = "68eda718-8dee-11e9-39e7-89f7f65f511f" GeoInterface = "cf35fbd7-0cd7-5166-be24-54bfbe79505f" diff --git a/test/test_convert.jl b/test/test_convert.jl index 327a8f2a..e222ef03 100644 --- a/test/test_convert.jl +++ b/test/test_convert.jl @@ -1,6 +1,12 @@ using Test import ArchGDAL as AG import GeoFormatTypes as GFT +using FixedPointNumbers + +struct CustomInt <: Integer + value::Int64 +end +Base.convert(::Type{Int64}, x::CustomInt) = x.value @testset "test_convert.jl" begin @@ -67,10 +73,12 @@ import GeoFormatTypes as GFT @test convert(AG.OGRFieldType, UInt32) == AG.OFTInteger64 @test convert(AG.OGRFieldType, Int32) == AG.OFTInteger @test convert(AG.OGRFieldType, Int64) == AG.OFTInteger64 + @test convert(AG.OGRFieldType, CustomInt) == AG.OFTInteger64 @test convert(AG.OGRFieldType, Float16) == AG.OFTReal @test convert(AG.OGRFieldType, Float32) == AG.OFTReal @test convert(AG.OGRFieldType, Float64) == AG.OFTReal + @test convert(AG.OGRFieldType, N0f16) == AG.OFTReal # Reverse conversion should result in default type, not subtype @test convert(DataType, AG.OFSTBoolean) == Bool diff --git a/test/test_feature.jl b/test/test_feature.jl index 2157f94f..48daf763 100644 --- a/test/test_feature.jl +++ b/test/test_feature.jl @@ -1,6 +1,7 @@ using Test import ArchGDAL as AG import GeoInterface as GI +using FixedPointNumbers @enum MyEnum::Bool begin MyEnumValue = false @@ -264,6 +265,12 @@ end AG.setsubtype!(fielddefn, AG.OFSTBoolean) return AG.addfielddefn!(layer, fielddefn) end + AG.createfielddefn("fixedpointfield", AG.OFTReal) do fielddefn + return AG.addfielddefn!(layer, fielddefn) + end + AG.createfielddefn("customintfield", AG.OFTInteger64) do fielddefn + return AG.addfielddefn!(layer, fielddefn) + end AG.createfeature(layer) do feature geojsonstring = "{ \"type\": \"Polygon\", \"coordinates\": [ [ [ 4, 44 ], [ 5, 44 ], [ 5, 45 ], [ 4, 45 ], [ 4, 44 ] ] ] }" AG.setfield!(feature, 0, Int64(1)) @@ -285,6 +292,8 @@ end AG.setfield!(feature, 16, UInt16(1.0)) AG.setfield!(feature, 17, UInt32(1.0)) AG.setfield!(feature, 18, MyEnumValue) + AG.setfield!(feature, 19, N0f16(1.0)) + AG.setfield!(feature, 20, CustomInt(1)) for i in 1:AG.nfield(feature) @test !AG.isfieldnull(feature, i - 1) @test AG.isfieldsetandnotnull(feature, i - 1) @@ -305,6 +314,8 @@ end @test AG.getfield(feature, 16) === Int32(1) # Widened from UInt16 @test AG.getfield(feature, 17) === Int64(1) # Widened from UInt32 @test AG.getfield(feature, 18) === false # Enum is lost + @test AG.getfield(feature, 19) === 1.0 # FixedPointNumber is lost + @test AG.getfield(feature, 20) === 1 # CustomInt is lost AG.addfeature(layer) do newfeature AG.setfrom!(newfeature, feature)