From a09f57b4828ed03fe2242517dd494740893260e1 Mon Sep 17 00:00:00 2001 From: Venkatesh-Prasad Ranganath Date: Fri, 27 Dec 2024 19:36:13 -0600 Subject: [PATCH] Use precise language The error message and documentation specifically refers to the variants of Enumerable#sum/product that do not support union types. --- spec/std/enumerable_spec.cr | 12 ++++++------ src/enumerable.cr | 7 ++++--- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/spec/std/enumerable_spec.cr b/spec/std/enumerable_spec.cr index 8847959d9aa8..5c66ddf55062 100644 --- a/spec/std/enumerable_spec.cr +++ b/spec/std/enumerable_spec.cr @@ -1373,9 +1373,9 @@ describe "Enumerable" do require "prelude" [1, 10000000000_u64].sum CRYSTAL - "Enumerable#sum and #product do not support Union types. Instead, " + - "use Enumerable#sum/product(initial) with an initial value of " + - "the expected type of the call." + "Enumerable#sum() and #product() do not support Union types. " + + "Instead, use Enumerable#sum and #product(initial), respectively, " + + "with an initial value of the intended type of the call." end it "uses additive_identity from type" do @@ -1427,9 +1427,9 @@ describe "Enumerable" do require "prelude" [1, 10000000000_u64].product CRYSTAL - "Enumerable#sum and #product do not support Union types. Instead, " + - "use Enumerable#sum/product(initial) with an initial value of " + - "the expected type of the call." + "Enumerable#sum() and #product() do not support Union types. " + + "Instead, use Enumerable#sum and #product(initial), respectively, " + + "with an initial value of the intended type of the call." end end diff --git a/src/enumerable.cr b/src/enumerable.cr index 2ec4b7456ae1..fb78d5c569ce 100644 --- a/src/enumerable.cr +++ b/src/enumerable.cr @@ -2299,9 +2299,10 @@ module Enumerable(T) def self.first {% if X.union? %} {{ - raise("Enumerable#sum and #product do not support Union types. " + - "Instead, use Enumerable#sum/product(initial) with an " + - "initial value of the expected type of the call.") + raise("Enumerable#sum() and #product() do not support Union types. " + + "Instead, use Enumerable#sum and #product(initial), " + + "respectively, with an initial value of the intended type " + + "of the call.") }} {% else %} X