Reputation: 27583
When writing Ruby (client scripts) I see three ways to build longer strings, including line-endings, all of which "smell" kind of ugly to me.
Are there any cleaner and nicer ways?
if render_quote?
quote = "Now that there is the Tec-9, a crappy spray gun from South Miami."
quote += "This gun is advertised as the most popular gun in American crime. Do you believe that shit?"
quote += "It actually says that in the little book that comes with it: the most popular gun in American crime."
quote += "Like they're actually proud of that shit."
puts quote
end
if render_quote?
quote =<<EOS
Now that there is the Tec-9, a crappy spray gun from South Miami.
This gun is advertised as the most popular gun in American crime. Do you believe that shit?
It actually says that in the little book that comes with it: the most popular gun in American crime.
Like they're actually proud of that shit.
EOS
puts quote
end
Or, by simply not adding a closing tag:
if render_quote?
quote = "Now that there is the Tec-9, a crappy spray gun from South Miami.
This gun is advertised as the most popular gun in American crime. Do you believe that shit?
It actually says that in the little book that comes with it: the most popular gun in American crime.
Like they're actually proud of that shit."
puts quote
end
Or, optionally, with a gsub to fix the identation-issues (yuk!?).
if render_quote?
quote = "Now that there is the Tec-9, a crappy spray gun from South Miami."
quote += "This gun is advertised as the most popular gun in American crime. Do you believe that shit?"
quote += "It actually says that in the little book that comes with it: the most popular gun in American crime."
quote += "Like they're actually proud of that shit."
puts quote
end
( quote from Samuel L. Ipsum )
I am aware that having such strings (i.e. view-logic) trough my scripts is a smell in itself, but don't know of a pattern (other then po-files or so) to clean this up.
Upvotes: 6
Views: 1221
Reputation: 42207
Since Ruby 2.3 you have the squiggly heredoc to avoid indentations in the string and still keep indentations in your code.
See here for more info.
Here the example from that page.
class Subscription
def warning_message
<<~HEREDOC
Subscription expiring soon!
Your free trial will expire in #{days_until_expiration} days.
Please update your billing information.
HEREDOC
end
end
If you don't mind the indentations you can also use the %Q{} syntax like this, the %Q gives string substitution, the %q not.
warning_message = %Q{
Subscription expiring soon!
Your free trial will expire in #{days_until_expiration} days.
Please update your billing information.
}
Upvotes: 2
Reputation: 11323
Your code wasn't working for me with the dash afterwards... but this works, doesn't require additional escaping of new lines, and simply says what it is doing on the HereDoc.
if render_quote?
quote = <<-EOS.strip.split.join(' ')
Now that there is the Tec-9, a crappy spray gun from South Miami.
This gun is advertised as the most popular gun in American crime. Do you believe that shit?
It actually says that in the little book that comes with it: the most popular gun in American crime.
Like they're actually proud of that shit.
EOS
puts quote
end
The dash before the EOS signifies that I will be able to use the EOS in an indented manner.
Upvotes: 2
Reputation: 168209
Note that adjacent string literals are concatenated. You can combine this with line-continuing character \
.
if render_quote?
quote =
"Now that there is the Tec-9, a crappy spray gun from South Miami. " \
"This gun is advertised as the most popular gun in American crime. " \
"Do you believe that shit?" \
"It actually says that in the little book that comes with it: " \
"the most popular gun in American crime. " \
"Like they're actually proud of that shit."
puts quote
end
Upvotes: 5