From a0346df1db5f92246c838093dd4aa6cbcb2529d3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrgen=20Fuhrmann?= Date: Sat, 16 Nov 2024 15:00:19 +0100 Subject: [PATCH] Update show method Have different methods for REPL and interpolation; make it compatible with planned improvement of show method for VoronoiFVM.System --- Project.toml | 2 +- src/extendablegrid.jl | 32 +++++++++++++++++++++++++++----- 2 files changed, 28 insertions(+), 6 deletions(-) diff --git a/Project.toml b/Project.toml index f2acfb82..15ea5860 100644 --- a/Project.toml +++ b/Project.toml @@ -1,7 +1,7 @@ name = "ExtendableGrids" uuid = "cfc395e8-590f-11e8-1f13-43a2532b2fa8" authors = ["Juergen Fuhrmann ", "Christian Merdon ", "Johannes Taraz ", "Patrick Jaap "] -version = "1.10.5" +version = "1.11" [deps] AbstractTrees = "1520ce14-60c1-5f80-bbc7-55ef81b5835c" diff --git a/src/extendablegrid.jl b/src/extendablegrid.jl index 87d69be8..a44033a5 100644 --- a/src/extendablegrid.jl +++ b/src/extendablegrid.jl @@ -541,16 +541,38 @@ function Base.map(f::Function, grid::ExtendableGrid{Tc, Ti}) where {Tc,Ti} end end +# +# Define two show methods, one extended for printing the repl, one +# compact for e.g. interpolating into a string +# See https://discourse.julialang.org/t/show-and-showcompact-on-custom-types/8493/6 +# +function Base.show(io::IO, ::MIME"text/plain", grid::ExtendableGrid) + str = @sprintf("%s\n dim = %7d\n nnodes = %7d\n ncells = %7d\n nbfaces = %7d", + typeof(grid), + dim_space(grid), num_nodes(grid), num_cells(grid), num_bfaces(grid)) + if num_edges(grid) > 0 + str*=@sprintf("\n nedges = %7d", num_edges(grid)) + end + if num_partitions(grid)>1 + str*="\n npartitions/color = $(num_partitions_per_color(grid))" + end + print(io, str) + nothing +end + function Base.show(io::IO, grid::ExtendableGrid) - str = @sprintf("%s;\ndim: %d nodes: %d cells: %d bfaces: %d", - typeof(grid), dim_space(grid), num_nodes(grid), num_cells(grid), num_bfaces(grid)) + str = @sprintf("%s(dim=%d, nnodes=%d, ncells=%d, nbfaces=%d", + typeof(grid), + dim_space(grid), num_nodes(grid), num_cells(grid), num_bfaces(grid)) if num_edges(grid) > 0 - str*=@sprintf(", edges: %d", num_edges(grid)) + str*=@sprintf(", nedges=%d", num_edges(grid)) end if num_partitions(grid)>1 - str*="\npartitions/color: $(num_partitions_per_color(grid))" + str*=", npart/color=$(num_partitions_per_color(grid))" end - println(io, str) + str*=")" + print(io, str) + nothing end ### Tests for the gmsh extension: