What is the use case for Ruby's %q / %Q quoting methods? What is the use case for Ruby's %q / %Q quoting methods? ruby ruby

What is the use case for Ruby's %q / %Q quoting methods?


They're extraordinarily useful for escaping HTML with JavaScript in it where you've already "run out" of quoting methods:

link = %q[<a href="javascript:method('call')">link</a>]

I've also found them to be very useful when working with multi-line SQL statements:

execute(%Q[  INSERT INTO table_a (column_a)    SELECT value      FROM table_b      WHERE key='value'])

The advantage there is you don't need to pay attention to the type of quoting used within your query. It will work with either single, double, or both. They're also a lot less fuss than the HEREDOC style method.

Ruby provides other convenience methods like this such as %r which can construct regular expressions. That avoids slash-itis when trying to write one that handles stuff like http:// that would otherwise have to be escaped.


Overview

Apart from "avoid internally escaping quotes" and the examples previously provided by @tadman there are other use-cases as well:

  • auto-generating code in the same language as the generator itself (e.g., Ruby generating Ruby)
  • providing cleanly-formatted code that does not confuse the syntax-highlighting feature of your text editor
  • allow storage of codeblocks that may have to pass through multiple storage layers (such as a database interacting with a website, or a snippets management system interacting with a text editor, which interacts with a subshell, and so forth)

Details

This approach is a general-purpose and robust idiom that works well with any kind of tool that does automated code generation, including but not limited to tools that write boilerplate code in other languages, or tools that manage code snippets for an IDE or text editor.

Besides the examples already provided by @tadman, there is the general case of generating code where the code being generated is the same or substantially similar syntax as the code of the generating program.

In these cases, the solution does a lot more than help with avoiding the use of backslashes to escape quotes. Without a solution like this, there are cases where the generated code can get extremely difficult to maintain.

To see examples of this, feel free to take a look at the following references.

References

[ See e.g.,

]


Its perhaps worth noting that %q is used by bundler and jeweler by default when generating gemspecs, for the summary/description section of the gemspec. This prevents someone from using quotes in the summary or description and breaking the gemspec.