]> git.madduck.net Git - etc/vim.git/blob - tests/data/preview/long_strings.py

madduck's git repository

Every one of the projects in this repository is available at the canonical URL git://git.madduck.net/madduck/pub/<projectpath> — see each project's metadata for the exact URL.

All patches and comments are welcome. Please squash your changes to logical commits before using git-format-patch and git-send-email to patches@git.madduck.net. If you'd read over the Git project's submission guidelines and adhered to them, I'd be especially grateful.

SSH access, as well as push access can be individually arranged.

If you use my repositories frequently, consider adding the following snippet to ~/.gitconfig and using the third clone URL listed for each project:

[url "git://git.madduck.net/madduck/"]
  insteadOf = madduck:

Improve long values in dict literals (#3440)
[etc/vim.git] / tests / data / preview / long_strings.py
1 x = "This is a really long string that can't possibly be expected to fit all together on one line. In fact it may even take up three or more lines... like four or five... but probably just three."
2
3 x += "This is a really long string that can't possibly be expected to fit all together on one line. In fact it may even take up three or more lines... like four or five... but probably just three."
4
5 y = (
6     'Short string'
7 )
8
9 print('This is a really long string inside of a print statement with extra arguments attached at the end of it.', x, y, z)
10
11 print("This is a really long string inside of a print statement with no extra arguments attached at the end of it.")
12
13 D1 = {"The First": "This is a really long string that can't possibly be expected to fit all together on one line. Also it is inside a dictionary, so formatting is more difficult.", "The Second": "This is another really really (not really) long string that also can't be expected to fit on one line and is, like the other string, inside a dictionary."}
14
15 D2 = {1.0: "This is a really long string that can't possibly be expected to fit all together on one line. Also it is inside a dictionary, so formatting is more difficult.", 2.0: "This is another really really (not really) long string that also can't be expected to fit on one line and is, like the other string, inside a dictionary."}
16
17 D3 = {x: "This is a really long string that can't possibly be expected to fit all together on one line. Also it is inside a dictionary, so formatting is more difficult.", y: "This is another really really (not really) long string that also can't be expected to fit on one line and is, like the other string, inside a dictionary."}
18
19 D4 = {"A long and ridiculous {}".format(string_key): "This is a really really really long string that has to go i,side of a dictionary. It is soooo bad.", some_func("calling", "some", "stuff"): "This is a really really really long string that has to go inside of a dictionary. It is {soooo} bad (#{x}).".format(sooo="soooo", x=2), "A %s %s" % ("formatted", "string"): "This is a really really really long string that has to go inside of a dictionary. It is %s bad (#%d)." % ("soooo", 2)}
20
21 D5 = {  # Test for https://github.com/psf/black/issues/3261
22     ("This is a really long string that can't be expected to fit in one line and is used as a nested dict's key"): {"inner": "value"},
23 }
24
25 D6 = {  # Test for https://github.com/psf/black/issues/3261
26     ("This is a really long string that can't be expected to fit in one line and is used as a dict's key"): ["value1", "value2"],
27 }
28
29 L1 = ["The is a short string", "This is a really long string that can't possibly be expected to fit all together on one line. Also it is inside a list literal, so it's expected to be wrapped in parens when spliting to avoid implicit str concatenation.", short_call("arg", {"key": "value"}), "This is another really really (not really) long string that also can't be expected to fit on one line and is, like the other string, inside a list literal.", ("parens should be stripped for short string in list")]
30
31 L2 = ["This is a really long string that can't be expected to fit in one line and is the only child of a list literal."]
32
33 S1 = {"The is a short string", "This is a really long string that can't possibly be expected to fit all together on one line. Also it is inside a set literal, so it's expected to be wrapped in parens when spliting to avoid implicit str concatenation.", short_call("arg", {"key": "value"}), "This is another really really (not really) long string that also can't be expected to fit on one line and is, like the other string, inside a set literal.", ("parens should be stripped for short string in set")}
34
35 S2 = {"This is a really long string that can't be expected to fit in one line and is the only child of a set literal."}
36
37 T1 = ("The is a short string", "This is a really long string that can't possibly be expected to fit all together on one line. Also it is inside a tuple literal, so it's expected to be wrapped in parens when spliting to avoid implicit str concatenation.", short_call("arg", {"key": "value"}), "This is another really really (not really) long string that also can't be expected to fit on one line and is, like the other string, inside a tuple literal.", ("parens should be stripped for short string in list"))
38
39 T2 = ("This is a really long string that can't be expected to fit in one line and is the only child of a tuple literal.",)
40
41 func_with_keywords(my_arg, my_kwarg="Long keyword strings also need to be wrapped, but they will probably need to be handled a little bit differently.")
42
43 bad_split1 = (
44     'But what should happen when code has already been formatted but in the wrong way? Like'
45     " with a space at the end instead of the beginning. Or what about when it is split too soon?"
46 )
47
48 bad_split2 = "But what should happen when code has already " \
49              "been formatted but in the wrong way? Like " \
50              "with a space at the end instead of the " \
51              "beginning. Or what about when it is split too " \
52              "soon? In the case of a split that is too " \
53              "short, black will try to honer the custom " \
54              "split."
55
56 bad_split3 = (
57     "What if we have inline comments on "  # First Comment
58     "each line of a bad split? In that "  # Second Comment
59     "case, we should just leave it alone."  # Third Comment
60 )
61
62 bad_split_func1(
63     "But what should happen when code has already "
64     "been formatted but in the wrong way? Like "
65     "with a space at the end instead of the "
66     "beginning. Or what about when it is split too "
67     "soon? In the case of a split that is too "
68     "short, black will try to honer the custom "
69     "split.",
70     xxx, yyy, zzz
71 )
72
73 bad_split_func2(
74     xxx, yyy, zzz,
75     long_string_kwarg="But what should happen when code has already been formatted but in the wrong way? Like "
76                       "with a space at the end instead of the beginning. Or what about when it is split too "
77                       "soon?",
78 )
79
80 bad_split_func3(
81     (
82         "But what should happen when code has already "
83         r"been formatted but in the wrong way? Like "
84         "with a space at the end instead of the "
85         r"beginning. Or what about when it is split too "
86         r"soon? In the case of a split that is too "
87         "short, black will try to honer the custom "
88         "split."
89     ),
90     xxx,
91     yyy,
92     zzz,
93 )
94
95 inline_comments_func1(
96     "if there are inline "
97     "comments in the middle "
98     # Here is the standard alone comment.
99     "of the implicitly concatenated "
100     "string, we should handle "
101     "them correctly",
102     xxx,
103 )
104
105 inline_comments_func2(
106     "what if the string is very very very very very very very very very very long and this part does "
107     "not fit into a single line? "
108     # Here is the standard alone comment.
109     "then the string should still be properly handled by merging and splitting "
110     "it into parts that fit in line length.",
111     xxx,
112 )
113
114 raw_string = r"This is a long raw string. When re-formatting this string, black needs to make sure it prepends the 'r' onto the new string."
115
116 fmt_string1 = "We also need to be sure to preserve any and all {} which may or may not be attached to the string in question.".format("method calls")
117
118 fmt_string2 = "But what about when the string is {} but {}".format("short", "the method call is really really really really really really really really long?")
119
120 old_fmt_string1 = "While we are on the topic of %s, we should also note that old-style formatting must also be preserved, since some %s still uses it." % ("formatting", "code")
121
122 old_fmt_string2 = "This is a %s %s %s %s" % ("really really really really really", "old", "way to format strings!", "Use f-strings instead!")
123
124 old_fmt_string3 = "Whereas only the strings after the percent sign were long in the last example, this example uses a long initial string as well. This is another %s %s %s %s" % ("really really really really really", "old", "way to format strings!", "Use f-strings instead!")
125
126 fstring = f"f-strings definitely make things more {difficult} than they need to be for {{black}}. But boy they sure are handy. The problem is that some lines will need to have the 'f' whereas others do not. This {line}, for example, needs one."
127
128 fstring_with_no_fexprs = f"Some regular string that needs to get split certainly but is NOT an fstring by any means whatsoever."
129
130 comment_string = "Long lines with inline comments should have their comments appended to the reformatted string's enclosing right parentheses."  # This comment gets thrown to the top.
131
132 arg_comment_string = print("Long lines with inline comments which are apart of (and not the only member of) an argument list should have their comments appended to the reformatted string's enclosing left parentheses.",  # This comment gets thrown to the top.
133     "Arg #2", "Arg #3", "Arg #4", "Arg #5")
134
135 pragma_comment_string1 = "Lines which end with an inline pragma comment of the form `# <pragma>: <...>` should be left alone."  # noqa: E501
136
137 pragma_comment_string2 = "Lines which end with an inline pragma comment of the form `# <pragma>: <...>` should be left alone."  # noqa
138
139 """This is a really really really long triple quote string and it should not be touched."""
140
141 triple_quote_string = """This is a really really really long triple quote string assignment and it should not be touched."""
142
143 assert some_type_of_boolean_expression, "Followed by a really really really long string that is used to provide context to the AssertionError exception."
144
145 assert some_type_of_boolean_expression, "Followed by a really really really long string that is used to provide context to the AssertionError exception, which uses dynamic string {}.".format("formatting")
146
147 assert some_type_of_boolean_expression, "Followed by a really really really long string that is used to provide context to the AssertionError exception, which uses dynamic string %s." % "formatting"
148
149 assert some_type_of_boolean_expression, "Followed by a really really really long string that is used to provide context to the AssertionError exception, which uses dynamic %s %s." % ("string", "formatting")
150
151 some_function_call("With a reallly generic name and with a really really long string that is, at some point down the line, " + added + " to a variable and then added to another string.")
152
153 some_function_call("With a reallly generic name and with a really really long string that is, at some point down the line, " + added + " to a variable and then added to another string. But then what happens when the final string is also supppppperrrrr long?! Well then that second (realllllllly long) string should be split too.", "and a second argument", and_a_third)
154
155 return "A really really really really really really really really really really really really really long {} {}".format("return", "value")
156
157 func_with_bad_comma(
158     "This is a really long string argument to a function that has a trailing comma which should NOT be there.",
159 )
160
161 func_with_bad_comma(
162     "This is a really long string argument to a function that has a trailing comma which should NOT be there.", # comment after comma
163 )
164
165 func_with_bad_comma(
166     (
167         "This is a really long string argument to a function that has a trailing comma"
168         " which should NOT be there."
169     ),
170 )
171
172 func_with_bad_comma(
173     (
174         "This is a really long string argument to a function that has a trailing comma"
175         " which should NOT be there."
176     ), # comment after comma
177 )
178
179 func_with_bad_parens_that_wont_fit_in_one_line(
180     ("short string that should have parens stripped"),
181     x,
182     y,
183     z
184 )
185
186 func_with_bad_parens_that_wont_fit_in_one_line(
187     x,
188     y,
189     ("short string that should have parens stripped"),
190     z
191 )
192
193 func_with_bad_parens(
194     ("short string that should have parens stripped"),
195     x,
196     y,
197     z,
198 )
199
200 func_with_bad_parens(
201     x,
202     y,
203     ("short string that should have parens stripped"),
204     z,
205 )
206
207 annotated_variable: Final = "This is a large " + STRING + " that has been " + CONCATENATED + "using the '+' operator."
208 annotated_variable: Final = "This is a large string that has a type annotation attached to it. A type annotation should NOT stop a long string from being wrapped."
209 annotated_variable: Literal["fakse_literal"] = "This is a large string that has a type annotation attached to it. A type annotation should NOT stop a long string from being wrapped."
210
211 backslashes = "This is a really long string with \"embedded\" double quotes and 'single' quotes that also handles checking for an even number of backslashes \\"
212 backslashes = "This is a really long string with \"embedded\" double quotes and 'single' quotes that also handles checking for an even number of backslashes \\\\"
213 backslashes = "This is a really 'long' string with \"embedded double quotes\" and 'single' quotes that also handles checking for an odd number of backslashes \\\", like this...\\\\\\"
214
215 short_string = (
216     "Hi"
217     " there."
218 )
219
220 func_call(
221     short_string=(
222         "Hi"
223         " there."
224     )
225 )
226
227 raw_strings = r"Don't" " get" r" merged" " unless they are all raw."
228
229 def foo():
230     yield "This is a really long string that can't possibly be expected to fit all together on one line. In fact it may even take up three or more lines... like four or five... but probably just three."
231
232 x = f"This is a {{really}} long string that needs to be split without a doubt (i.e. most definitely). In short, this {string} that can't possibly be {{expected}} to fit all together on one line. In {fact} it may even take up three or more lines... like four or five... but probably just four."
233
234 long_unmergable_string_with_pragma = (
235     "This is a really long string that can't be merged because it has a likely pragma at the end"  # type: ignore
236     " of it."
237 )
238
239 long_unmergable_string_with_pragma = (
240     "This is a really long string that can't be merged because it has a likely pragma at the end"  # noqa
241     " of it."
242 )
243
244 long_unmergable_string_with_pragma = (
245     "This is a really long string that can't be merged because it has a likely pragma at the end"  # pylint: disable=some-pylint-check
246     " of it."
247 )
248
249 string_with_nameescape = (
250     "........................................................................ \N{LAO KO LA}"
251 )
252
253 string_with_nameescape = (
254     "........................................................................... \N{LAO KO LA}"
255 )
256
257 string_with_nameescape = (
258     "............................................................................ \N{LAO KO LA}"
259 )
260
261 string_with_nameescape_and_escaped_backslash = (
262     "...................................................................... \\\N{LAO KO LA}"
263 )
264
265 string_with_nameescape_and_escaped_backslash = (
266     "......................................................................... \\\N{LAO KO LA}"
267 )
268
269 string_with_nameescape_and_escaped_backslash = (
270     ".......................................................................... \\\N{LAO KO LA}"
271 )
272
273 string_with_escaped_nameescape = (
274     "........................................................................ \\N{LAO KO LA}"
275 )
276
277 string_with_escaped_nameescape = (
278     "........................................................................... \\N{LAO KO LA}"
279 )
280
281 msg = lambda x: f"this is a very very very long lambda value {x} that doesn't fit on a single line"
282
283 dict_with_lambda_values = {
284     "join": lambda j: (
285         f"{j.__class__.__name__}({some_function_call(j.left)}, "
286         f"{some_function_call(j.right)})"
287     ),
288 }
289
290
291 # output
292
293
294 x = (
295     "This is a really long string that can't possibly be expected to fit all together"
296     " on one line. In fact it may even take up three or more lines... like four or"
297     " five... but probably just three."
298 )
299
300 x += (
301     "This is a really long string that can't possibly be expected to fit all together"
302     " on one line. In fact it may even take up three or more lines... like four or"
303     " five... but probably just three."
304 )
305
306 y = "Short string"
307
308 print(
309     (
310         "This is a really long string inside of a print statement with extra arguments"
311         " attached at the end of it."
312     ),
313     x,
314     y,
315     z,
316 )
317
318 print(
319     "This is a really long string inside of a print statement with no extra arguments"
320     " attached at the end of it."
321 )
322
323 D1 = {
324     "The First": (
325         "This is a really long string that can't possibly be expected to fit all"
326         " together on one line. Also it is inside a dictionary, so formatting is more"
327         " difficult."
328     ),
329     "The Second": (
330         "This is another really really (not really) long string that also can't be"
331         " expected to fit on one line and is, like the other string, inside a"
332         " dictionary."
333     ),
334 }
335
336 D2 = {
337     1.0: (
338         "This is a really long string that can't possibly be expected to fit all"
339         " together on one line. Also it is inside a dictionary, so formatting is more"
340         " difficult."
341     ),
342     2.0: (
343         "This is another really really (not really) long string that also can't be"
344         " expected to fit on one line and is, like the other string, inside a"
345         " dictionary."
346     ),
347 }
348
349 D3 = {
350     x: (
351         "This is a really long string that can't possibly be expected to fit all"
352         " together on one line. Also it is inside a dictionary, so formatting is more"
353         " difficult."
354     ),
355     y: (
356         "This is another really really (not really) long string that also can't be"
357         " expected to fit on one line and is, like the other string, inside a"
358         " dictionary."
359     ),
360 }
361
362 D4 = {
363     "A long and ridiculous {}".format(string_key): (
364         "This is a really really really long string that has to go i,side of a"
365         " dictionary. It is soooo bad."
366     ),
367     some_func("calling", "some", "stuff"): (
368         "This is a really really really long string that has to go inside of a"
369         " dictionary. It is {soooo} bad (#{x}).".format(sooo="soooo", x=2)
370     ),
371     "A %s %s"
372     % ("formatted", "string"): (
373         "This is a really really really long string that has to go inside of a"
374         " dictionary. It is %s bad (#%d)." % ("soooo", 2)
375     ),
376 }
377
378 D5 = {  # Test for https://github.com/psf/black/issues/3261
379     "This is a really long string that can't be expected to fit in one line and is used as a nested dict's key": {
380         "inner": "value"
381     },
382 }
383
384 D6 = {  # Test for https://github.com/psf/black/issues/3261
385     "This is a really long string that can't be expected to fit in one line and is used as a dict's key": [
386         "value1",
387         "value2",
388     ],
389 }
390
391 L1 = [
392     "The is a short string",
393     (
394         "This is a really long string that can't possibly be expected to fit all"
395         " together on one line. Also it is inside a list literal, so it's expected to"
396         " be wrapped in parens when spliting to avoid implicit str concatenation."
397     ),
398     short_call("arg", {"key": "value"}),
399     (
400         "This is another really really (not really) long string that also can't be"
401         " expected to fit on one line and is, like the other string, inside a list"
402         " literal."
403     ),
404     "parens should be stripped for short string in list",
405 ]
406
407 L2 = [
408     "This is a really long string that can't be expected to fit in one line and is the"
409     " only child of a list literal."
410 ]
411
412 S1 = {
413     "The is a short string",
414     (
415         "This is a really long string that can't possibly be expected to fit all"
416         " together on one line. Also it is inside a set literal, so it's expected to be"
417         " wrapped in parens when spliting to avoid implicit str concatenation."
418     ),
419     short_call("arg", {"key": "value"}),
420     (
421         "This is another really really (not really) long string that also can't be"
422         " expected to fit on one line and is, like the other string, inside a set"
423         " literal."
424     ),
425     "parens should be stripped for short string in set",
426 }
427
428 S2 = {
429     "This is a really long string that can't be expected to fit in one line and is the"
430     " only child of a set literal."
431 }
432
433 T1 = (
434     "The is a short string",
435     (
436         "This is a really long string that can't possibly be expected to fit all"
437         " together on one line. Also it is inside a tuple literal, so it's expected to"
438         " be wrapped in parens when spliting to avoid implicit str concatenation."
439     ),
440     short_call("arg", {"key": "value"}),
441     (
442         "This is another really really (not really) long string that also can't be"
443         " expected to fit on one line and is, like the other string, inside a tuple"
444         " literal."
445     ),
446     "parens should be stripped for short string in list",
447 )
448
449 T2 = (
450     (
451         "This is a really long string that can't be expected to fit in one line and is"
452         " the only child of a tuple literal."
453     ),
454 )
455
456 func_with_keywords(
457     my_arg,
458     my_kwarg=(
459         "Long keyword strings also need to be wrapped, but they will probably need to"
460         " be handled a little bit differently."
461     ),
462 )
463
464 bad_split1 = (
465     "But what should happen when code has already been formatted but in the wrong way?"
466     " Like with a space at the end instead of the beginning. Or what about when it is"
467     " split too soon?"
468 )
469
470 bad_split2 = (
471     "But what should happen when code has already "
472     "been formatted but in the wrong way? Like "
473     "with a space at the end instead of the "
474     "beginning. Or what about when it is split too "
475     "soon? In the case of a split that is too "
476     "short, black will try to honer the custom "
477     "split."
478 )
479
480 bad_split3 = (
481     "What if we have inline comments on "  # First Comment
482     "each line of a bad split? In that "  # Second Comment
483     "case, we should just leave it alone."  # Third Comment
484 )
485
486 bad_split_func1(
487     (
488         "But what should happen when code has already "
489         "been formatted but in the wrong way? Like "
490         "with a space at the end instead of the "
491         "beginning. Or what about when it is split too "
492         "soon? In the case of a split that is too "
493         "short, black will try to honer the custom "
494         "split."
495     ),
496     xxx,
497     yyy,
498     zzz,
499 )
500
501 bad_split_func2(
502     xxx,
503     yyy,
504     zzz,
505     long_string_kwarg=(
506         "But what should happen when code has already been formatted but in the wrong"
507         " way? Like with a space at the end instead of the beginning. Or what about"
508         " when it is split too soon?"
509     ),
510 )
511
512 bad_split_func3(
513     (
514         "But what should happen when code has already "
515         r"been formatted but in the wrong way? Like "
516         "with a space at the end instead of the "
517         r"beginning. Or what about when it is split too "
518         r"soon? In the case of a split that is too "
519         "short, black will try to honer the custom "
520         "split."
521     ),
522     xxx,
523     yyy,
524     zzz,
525 )
526
527 inline_comments_func1(
528     "if there are inline comments in the middle "
529     # Here is the standard alone comment.
530     "of the implicitly concatenated string, we should handle them correctly",
531     xxx,
532 )
533
534 inline_comments_func2(
535     "what if the string is very very very very very very very very very very long and"
536     " this part does not fit into a single line? "
537     # Here is the standard alone comment.
538     "then the string should still be properly handled by merging and splitting "
539     "it into parts that fit in line length.",
540     xxx,
541 )
542
543 raw_string = (
544     r"This is a long raw string. When re-formatting this string, black needs to make"
545     r" sure it prepends the 'r' onto the new string."
546 )
547
548 fmt_string1 = (
549     "We also need to be sure to preserve any and all {} which may or may not be"
550     " attached to the string in question.".format("method calls")
551 )
552
553 fmt_string2 = "But what about when the string is {} but {}".format(
554     "short",
555     "the method call is really really really really really really really really long?",
556 )
557
558 old_fmt_string1 = (
559     "While we are on the topic of %s, we should also note that old-style formatting"
560     " must also be preserved, since some %s still uses it." % ("formatting", "code")
561 )
562
563 old_fmt_string2 = "This is a %s %s %s %s" % (
564     "really really really really really",
565     "old",
566     "way to format strings!",
567     "Use f-strings instead!",
568 )
569
570 old_fmt_string3 = (
571     "Whereas only the strings after the percent sign were long in the last example,"
572     " this example uses a long initial string as well. This is another %s %s %s %s"
573     % (
574         "really really really really really",
575         "old",
576         "way to format strings!",
577         "Use f-strings instead!",
578     )
579 )
580
581 fstring = (
582     f"f-strings definitely make things more {difficult} than they need to be for"
583     " {black}. But boy they sure are handy. The problem is that some lines will need"
584     f" to have the 'f' whereas others do not. This {line}, for example, needs one."
585 )
586
587 fstring_with_no_fexprs = (
588     f"Some regular string that needs to get split certainly but is NOT an fstring by"
589     f" any means whatsoever."
590 )
591
592 comment_string = (  # This comment gets thrown to the top.
593     "Long lines with inline comments should have their comments appended to the"
594     " reformatted string's enclosing right parentheses."
595 )
596
597 arg_comment_string = print(
598     (  # This comment gets thrown to the top.
599         "Long lines with inline comments which are apart of (and not the only member"
600         " of) an argument list should have their comments appended to the reformatted"
601         " string's enclosing left parentheses."
602     ),
603     "Arg #2",
604     "Arg #3",
605     "Arg #4",
606     "Arg #5",
607 )
608
609 pragma_comment_string1 = "Lines which end with an inline pragma comment of the form `# <pragma>: <...>` should be left alone."  # noqa: E501
610
611 pragma_comment_string2 = "Lines which end with an inline pragma comment of the form `# <pragma>: <...>` should be left alone."  # noqa
612
613 """This is a really really really long triple quote string and it should not be touched."""
614
615 triple_quote_string = """This is a really really really long triple quote string assignment and it should not be touched."""
616
617 assert some_type_of_boolean_expression, (
618     "Followed by a really really really long string that is used to provide context to"
619     " the AssertionError exception."
620 )
621
622 assert some_type_of_boolean_expression, (
623     "Followed by a really really really long string that is used to provide context to"
624     " the AssertionError exception, which uses dynamic string {}.".format("formatting")
625 )
626
627 assert some_type_of_boolean_expression, (
628     "Followed by a really really really long string that is used to provide context to"
629     " the AssertionError exception, which uses dynamic string %s." % "formatting"
630 )
631
632 assert some_type_of_boolean_expression, (
633     "Followed by a really really really long string that is used to provide context to"
634     " the AssertionError exception, which uses dynamic %s %s."
635     % ("string", "formatting")
636 )
637
638 some_function_call(
639     "With a reallly generic name and with a really really long string that is, at some"
640     " point down the line, "
641     + added
642     + " to a variable and then added to another string."
643 )
644
645 some_function_call(
646     "With a reallly generic name and with a really really long string that is, at some"
647     " point down the line, "
648     + added
649     + " to a variable and then added to another string. But then what happens when the"
650     " final string is also supppppperrrrr long?! Well then that second (realllllllly"
651     " long) string should be split too.",
652     "and a second argument",
653     and_a_third,
654 )
655
656 return (
657     "A really really really really really really really really really really really"
658     " really really long {} {}".format("return", "value")
659 )
660
661 func_with_bad_comma(
662     (
663         "This is a really long string argument to a function that has a trailing comma"
664         " which should NOT be there."
665     ),
666 )
667
668 func_with_bad_comma(
669     (  # comment after comma
670         "This is a really long string argument to a function that has a trailing comma"
671         " which should NOT be there."
672     ),
673 )
674
675 func_with_bad_comma(
676     (
677         "This is a really long string argument to a function that has a trailing comma"
678         " which should NOT be there."
679     ),
680 )
681
682 func_with_bad_comma(
683     (  # comment after comma
684         "This is a really long string argument to a function that has a trailing comma"
685         " which should NOT be there."
686     ),
687 )
688
689 func_with_bad_parens_that_wont_fit_in_one_line(
690     "short string that should have parens stripped", x, y, z
691 )
692
693 func_with_bad_parens_that_wont_fit_in_one_line(
694     x, y, "short string that should have parens stripped", z
695 )
696
697 func_with_bad_parens(
698     "short string that should have parens stripped",
699     x,
700     y,
701     z,
702 )
703
704 func_with_bad_parens(
705     x,
706     y,
707     "short string that should have parens stripped",
708     z,
709 )
710
711 annotated_variable: Final = (
712     "This is a large "
713     + STRING
714     + " that has been "
715     + CONCATENATED
716     + "using the '+' operator."
717 )
718 annotated_variable: Final = (
719     "This is a large string that has a type annotation attached to it. A type"
720     " annotation should NOT stop a long string from being wrapped."
721 )
722 annotated_variable: Literal["fakse_literal"] = (
723     "This is a large string that has a type annotation attached to it. A type"
724     " annotation should NOT stop a long string from being wrapped."
725 )
726
727 backslashes = (
728     "This is a really long string with \"embedded\" double quotes and 'single' quotes"
729     " that also handles checking for an even number of backslashes \\"
730 )
731 backslashes = (
732     "This is a really long string with \"embedded\" double quotes and 'single' quotes"
733     " that also handles checking for an even number of backslashes \\\\"
734 )
735 backslashes = (
736     "This is a really 'long' string with \"embedded double quotes\" and 'single' quotes"
737     ' that also handles checking for an odd number of backslashes \\", like'
738     " this...\\\\\\"
739 )
740
741 short_string = "Hi there."
742
743 func_call(short_string="Hi there.")
744
745 raw_strings = r"Don't" " get" r" merged" " unless they are all raw."
746
747
748 def foo():
749     yield (
750         "This is a really long string that can't possibly be expected to fit all"
751         " together on one line. In fact it may even take up three or more lines... like"
752         " four or five... but probably just three."
753     )
754
755
756 x = (
757     "This is a {really} long string that needs to be split without a doubt (i.e."
758     f" most definitely). In short, this {string} that can't possibly be {{expected}} to"
759     f" fit all together on one line. In {fact} it may even take up three or more"
760     " lines... like four or five... but probably just four."
761 )
762
763 long_unmergable_string_with_pragma = (
764     "This is a really long string that can't be merged because it has a likely pragma at the end"  # type: ignore
765     " of it."
766 )
767
768 long_unmergable_string_with_pragma = (
769     "This is a really long string that can't be merged because it has a likely pragma at the end"  # noqa
770     " of it."
771 )
772
773 long_unmergable_string_with_pragma = (
774     "This is a really long string that can't be merged because it has a likely pragma at the end"  # pylint: disable=some-pylint-check
775     " of it."
776 )
777
778 string_with_nameescape = (
779     "........................................................................"
780     " \N{LAO KO LA}"
781 )
782
783 string_with_nameescape = (
784     "..........................................................................."
785     " \N{LAO KO LA}"
786 )
787
788 string_with_nameescape = (
789     "............................................................................"
790     " \N{LAO KO LA}"
791 )
792
793 string_with_nameescape_and_escaped_backslash = (
794     "......................................................................"
795     " \\\N{LAO KO LA}"
796 )
797
798 string_with_nameescape_and_escaped_backslash = (
799     "........................................................................."
800     " \\\N{LAO KO LA}"
801 )
802
803 string_with_nameescape_and_escaped_backslash = (
804     ".........................................................................."
805     " \\\N{LAO KO LA}"
806 )
807
808 string_with_escaped_nameescape = (
809     "........................................................................ \\N{LAO"
810     " KO LA}"
811 )
812
813 string_with_escaped_nameescape = (
814     "..........................................................................."
815     " \\N{LAO KO LA}"
816 )
817
818 msg = (
819     lambda x: (
820         f"this is a very very very long lambda value {x} that doesn't fit on a single"
821         " line"
822     )
823 )
824
825 dict_with_lambda_values = {
826     "join": lambda j: (
827         f"{j.__class__.__name__}({some_function_call(j.left)}, "
828         f"{some_function_call(j.right)})"
829     ),
830 }