From c7234e7e63af7e21526195a6162db02f57f47106 Mon Sep 17 00:00:00 2001 From: Nenad Lukic Date: Thu, 26 Sep 2024 20:11:25 +0300 Subject: [PATCH] Add a check whether default_ignore file is empty during execution and ignores it if is --- lib/dialyxir/filter_map.ex | 21 ++++++++++++++------- lib/mix/tasks/dialyzer.ex | 6 ++++++ 2 files changed, 20 insertions(+), 7 deletions(-) diff --git a/lib/dialyxir/filter_map.ex b/lib/dialyxir/filter_map.ex index 6b6035f2..f79d92af 100644 --- a/lib/dialyxir/filter_map.ex +++ b/lib/dialyxir/filter_map.ex @@ -16,14 +16,21 @@ defmodule Dialyxir.FilterMap do unused_filters_as_errors?: list_unused_filters? && !ignore_exit_status? } - {ignore, _} = - ignore_file - |> File.read!() - |> Code.eval_string() + cond do + File.exists?(ignore_file) && + match?(%{size: size} when size > 0, File.stat!(ignore_file)) -> + {ignore, _} = + ignore_file + |> File.read!() + |> Code.eval_string() - Enum.reduce(ignore, filter_map, fn skip, filter_map -> - put_in(filter_map.counters[skip], 0) - end) + Enum.reduce(ignore, filter_map, fn skip, filter_map -> + put_in(filter_map.counters[skip], 0) + end) + + true -> + filter_map + end end @doc """ diff --git a/lib/mix/tasks/dialyzer.ex b/lib/mix/tasks/dialyzer.ex index b545aaf4..ceca8445 100644 --- a/lib/mix/tasks/dialyzer.ex +++ b/lib/mix/tasks/dialyzer.ex @@ -187,6 +187,12 @@ defmodule Mix.Tasks.Dialyzer do No :ignore_warnings opt specified in mix.exs. Using default: #{default}. """) + ignore_warnings && File.exists?(ignore_warnings) && + match?(%{size: size} when size == 0, File.stat!(default)) -> + info(""" + :ignore_warnings opt specified in mix.exs: #{ignore_warnings}, but file is empty. + """) + ignore_warnings && File.exists?(ignore_warnings) -> info(""" ignore_warnings: #{ignore_warnings}