The question 'How does Google Closure Compiler handle quotes (string literals)?' could also be re-phrased like:
- Why does Closure replace/swap single quotes with double quotes?
- How does Closure decide what quote- formatting/style to use?
- (How) can I change this (default) behavior?
Note 1: this question is not about why Closure (or some other minifiers) have chosen to prefer double quotes (as is asked here and here).
Note 2: this question is not about single vs double quote discussions, however some understanding what GCC does to our code (and why) is rather useful!
It is often stated that (or asked why) Google Closure Compiler (GCC) replaces single quotes with double-quotes (even when the
compilation_level
is set toWHITESPACE_ONLY
!!!):example xmp_1.js:
However... this is only half of 'the truth', because:
example xmp_2.js:
GCC is essentially a 'your raw javascript' to 'smaller (and more efficient) javascript' translator: so it does not 'blindly' replace single quotes with double quotes, but tries to choose an 'optimal quote-character' (after all.. one of the primary goals is to 'mini-fy' the script).
From the source-code (CompilerOptions.java) and this issue-report one can learn that:
Like this example xmp_3.js:
Note how the above xmp_3 results in a 'mixed' output that uses both
'
and"
as outer quotation: the optimal choice followed by the default (when it didn't matter).How to change/override the default double quotes to single quotes?
As it turned out there are some serious legitimate real-world cases where defaulting to single-quotes would have been better. As explained in the issue 836 (from Oct 8, 2012) referenced above:
The reporter of the issue came with a gift: a patch that added the option
prefer_single_quotes
to change the default quote-character from double quote to single quote.This issue was taken seriously enough that project member Santos considered changing the default double quote to single quote ('and see if anybody complains').. TWICE (also after the reporter/patch-contributer stated that he implemented it as an option so that it wouldn't have any backward-compatibility consequences since 'someone might be relying on strings being output with double quotes for some bizarre reason').
However, about one week later the patch was accepted (r2258), another week later reworked (r2257) and on Oct 30, 2012 Santos reported back that the option could now be enabled with:
--formatting=SINGLE_QUOTES
(so a third option besides
PRETTY_PRINT
andPRINT_INPUT_DELIMITER
for theformatting
-key).(Note: in the current source-code one can currently still find numerous references to 'prefer_single_quotes' as well.)
Usage:
If you (download and) use the (local java) application:
java -jar compiler.jar --js xmp_1.js --formatting SINGLE_QUOTES
and you will see that:alert('Hello world!');
now compiles toalert('Hello world!');
However, at this time of writing, the Compiler Service API and UI (that most probably uses the API) located at http://closure-compiler.appspot.com, do not accept this third (new, although a year in existence) formatting-option:
SINGLE_QUOTES
and will throw an error:17: Unknown formatting option single_quotes.
After digging (again) through the source, it seems (I'm not a Java-expert) that this is because jscomp/webservice/common/Protocol.java only accepts the older
PRETTY_PRINT
andPRINT_INPUT_DELIMITER
I will update this answer should this option become available in the API and/or UI.
Hope this helps and saves someone some time, since the only documentation and reference google can find about
SINGLE_QUOTES
is currently in this one issue 836 and some comments in the source. Now it has some explanation on SO (where I'd expect it).