Project

General

Profile

Actions

Feature #3450

closed

Format Strings with Named Arguments & Hash#default

Added by runpaint (Run Paint Run Run) over 14 years ago. Updated about 7 years ago.

Status:
Closed
Target version:
[ruby-core:30803]

Description

=begin
Is it intentional that the, undocumented, feature #442 (named arguments in format strings) ignores the Hash's default value?

hash = {greeting: 'Hello'}.tap{|h| h.default = 'World'}
'%{greeting}, %{greeted}' % hash
#=> KeyError: key{greeted} not found

It's quite common for templates to use default values. In interface localisation, untranslated strings may need to be substituted for the equivalent in the native language, or replaced with a generic string in the target language. When building reports with format strings, a default value of an empty string allows unexpanded format sequences to be non-fatal. In both cases, a default proc would provide even further flexibility.

Another perspective is that this behavior unnecessarily breaks the abstraction that default values are just like any other.
=end


Files

3450.patch (578 Bytes) 3450.patch judofyr (Magnus Holm), 06/18/2010 07:07 PM
Actions #1

Updated by judofyr (Magnus Holm) over 14 years ago

=begin
I believe this patch should fix it, but this also has the side effect that KeyError will never be raised (since it will always use the default value, which is nil be default). There's probably some more code which can be removed if we apply the patch, but it seems to me that this is intentional behaviour though…
=end

Updated by nahi (Hiroshi Nakamura) almost 13 years ago

  • Description updated (diff)
  • Assignee set to nobu (Nobuyoshi Nakada)
Actions #3

Updated by shyouhei (Shyouhei Urabe) almost 13 years ago

  • Status changed from Open to Assigned

Updated by mame (Yusuke Endoh) about 12 years ago

  • Target version changed from 2.0.0 to 2.6

Updated by nobu (Nobuyoshi Nakada) about 12 years ago

I think this is a trade-off.
Silently ignoring undefined keys may not preferable for somebody.
I don't think differentiating simple default value and default proc is good idea.

Updated by matz (Yukihiro Matsumoto) about 7 years ago

  • Status changed from Assigned to Closed

Already fixed.

Matz.

Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0Like0Like0