From c9e73b9d7d9f6a7c2e2df3276a023e9861f750fb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Legat?= Date: Thu, 8 Aug 2024 09:08:02 +0200 Subject: [PATCH] New approach --- src/file_formats.jl | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/file_formats.jl b/src/file_formats.jl index 9dc1f62bc53..35f1dc5cf5e 100644 --- a/src/file_formats.jl +++ b/src/file_formats.jl @@ -88,6 +88,14 @@ function Base.write( return end +_value_type(model::MOI.Utilities.AbstractModelLike{T}) where {T} = T + +# This fallback may not get the correct value type. However, since +# all models defined in `MOI.FileFormats` are created with +# `MOI.Utilities.@model` except `NL` which only supports `Float64`, +# this does the job for now. +_value_type(model::MOI.ModelLike) = Float64 + """ read_from_file( filename::String; @@ -105,12 +113,11 @@ Other `kwargs` are passed to the `Model` constructor of the chosen format. function read_from_file( filename::String; format::MOI.FileFormats.FileFormat = MOI.FileFormats.FORMAT_AUTOMATIC, - coefficient_type::Type = Float64, kwargs..., ) - src = MOI.FileFormats.Model(; format, filename, coefficient_type, kwargs...) + src = MOI.FileFormats.Model(; format, filename, kwargs...) MOI.read_from_file(src, filename) - model = GenericModel{coefficient_type}() + model = GenericModel{_value_type(model)}() MOI.copy_to(model, src) return model end