This patch fixes an issue where the UnbreakableTailLength would be counted towards
the length of a token during breaking, even though we can break after the token.
For example, this proto text with column limit 20
# ColumnLimit: 20 V foo: { bar: { bazoo: "aaaaaaa" } }
was broken:
# ColumnLimit: 20 V foo: { bar: { bazoo: "aaaaaaa" } }
because the 2 closing } were counted towards the string literal's UnbreakableTailLength.
I think a comment might help here. Specifically, it should mention that this is required for the special case where there is an unbreakable tail only if certain other formatting decisions have been taken. The UnbreakableTailLength is an overapproximation in that case and we need to be correct here.
Thinking about this some more, there might actually be cases where this is still not correct as the unbreakable tail is neither 0 nor the precomputed value.
E.g. can we construct a case where there is a trailing comma in a braced list? Maybe this:
vector<string> x = {"aaaaaa",};
In this case, I think the comma will always be part of the string literal, but the "};" only get part of the tail if we don't wrap after the "{".