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.
3 result = type(message)("")
6 # Don't merge multiline (e.g. triple-quoted) strings.
9 """SELECT xxxxxxxxxxxxxxxxxxxx(xxx)"""
10 """ FROM xxxxxxxxxxxxxxxx WHERE xxxxxxxxxx AND xxx <> xxxxxxxxxxxxxx()""")
12 # There was a bug where tuples were being identified as long strings.
13 long_tuple = ('Apple', 'Berry', 'Cherry', 'Dill', 'Evergreen', 'Fig',
14 'Grape', 'Harry', 'Iglu', 'Jaguar')
16 stupid_format_method_bug = "Some really long string that just so happens to be the {} {} to force the 'format' method to hang over the line length boundary. This is pretty annoying.".format("perfect", "length")
20 os.system("This is a regression test. xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxxx.".format("xxxxxxxxxx", "xxxxxx", "xxxxxxxxxx"))
27 "xxx_xxxxxxxxxx(xxxxx={}, xxxx={}, xxxxx, xxxx_xxxx_xxxxxxxxxx={})".format(
28 xxxxx, xxxx, xxxx_xxxx_xxxxxxxxxx
40 "[{}]: xxx_xxxxxxxxxx(xxxxx={}, xxxx={}, xxxxx={}"
41 " xxxx_xxxx_xxxxxxxxxx={}, xxxx={})"
42 .format(xxxx._xxxxxxxxxxxxxx, xxxxx, xxxx, xxxx_xxxx_xxxxxxxxxx, xxxxxxx)
50 for (xxx_xxxx, _xxx_xxx, _xxx_xxxxx, xxx_xxxx) in xxxx:
52 assert ("x" in xxx) or (
54 ), "{0} xxxxxxx xx {1}, xxx {1} xx xxx xx xxxx xx xxx xxxx: xxx xxxx {2}".format(
55 xxx_xxxx, xxx, xxxxxx.xxxxxxx(xxx_xxx_xxxxx)
59 def disappearing_comment():
61 ( # xx -x xxxxxxx xx xxx xxxxxxx.
62 '{{xxx_xxxxxxxxxx_xxxxxxxx}} xxx xxxx'
66 if xxxxx.xx_xxxxxxxxxx
67 else ( # Disappearing Comment
68 "--xxxxxxx --xxxxxx=x --xxxxxx-xxxxx=xxxxxx"
69 " --xxxxxx-xxxx=xxxxxxxxxxx.xxx"
81 "@xxxxxx '{xxxx_xxx}\t' > {xxxxxx_xxxx}.xxxxxxx;"
82 "{xxxx_xxx} >> {xxxxxx_xxxx}.xxxxxxx 2>&1; xx=$$?;"
84 .format(xxxx_xxx=xxxx_xxxxxxx, xxxxxx_xxxx=xxxxxxx + "/" + xxxx_xxx_xxxx, x=xxx_xxxxx_xxxxx_xxx),
90 func_call_where_string_arg_has_method_call_and_bad_parens(
92 "A long string with {}. This string is so long that it is ridiculous. It can't fit on one line at alllll.".format("formatting")
96 func_call_where_string_arg_has_old_fmt_and_bad_parens(
98 "A long string with {}. This string is so long that it is ridiculous. It can't fit on one line at alllll." % "formatting"
102 func_call_where_string_arg_has_old_fmt_and_bad_parens(
104 "A long string with {}. This {} is so long that it is ridiculous. It can't fit on one line at alllll." % ("formatting", "string")
111 xxxx.xxxxxxx.xxxxx( ('xxxxxxxxxx xxxx xx xxxxxx(%x) xx %x xxxx xx xxx %x.xx'
115 + (' %.3f (%s) to %.3f (%s).\n'
117 xxxx.xxxxxxxxxxxxxx(xxxx.xxxxxxxxx),
119 xxxx.xxxxxxxxxxxxxx( xx)
127 "xx {xxxxxxxxxxx}/xxxxxxxxxxx.xxx xxxx.xxx && xxxxxx -x "
128 "\"xxxx xxxxxxx xxxxxx xxxx; xxxx xxxxxx_xxxxx xxxxxx xxxx; "
129 "xxxx.xxxx_xxxxxx(['xxxx.xxx'], xxxx.xxxxxxx().xxxxxxxxxx)\" "
139 "xx {xxxxxxxxxxx}/xxxxxxxxxxx.xxx xxxx.xxx && xxxxxx -x "
140 "xxxx, ('xxxxxxx xxxxxx xxxx, xxxx') xxxxxx_xxxxx xxxxxx xxxx; "
141 "xxxx.xxxx_xxxxxx(['xxxx.xxx'], xxxx.xxxxxxx().xxxxxxxxxx)\" "
147 xxxxxxx = { 'xx' : 'xxxx xxxxxxx xxxxxxxxx -x xxx -x /xxx/{0} -x xxx,xxx -xx {1} \
148 -xx {1} -xx xxx=xxx_xxxx,xxx_xx,xxx_xxx,xxx_xxxx,xxx_xx,xxx_xxx |\
149 xxxxxx -x xxxxxxxx -x xxxxxxxx -x',
150 'xx' : 'xxxx xxxxxxx xxxxxxxxx -x xxx -x /xxx/{0} -x xxx,xxx -xx {1} \
151 -xx {1} -xx xxx=xxx_xxxx_xxx_xxxx,xxx_xx_xxx_xxxx,xxx_xxxx_xxx_xxxx,\
152 xxx_xx_xxxx_xxxx,xxx_xxx_xxxx,xxx_xxx_xxxx xxxx=xxx | xxxxxx -x xxxxxxxx -x xxxxxxxx -x'
158 xxxxx_xxxxxxxxxxxx('xxx xxxxxx xxx xxxxxxxxx.xx xx xxxxxxxx. xxx xxxxxxxxxxxxx.xx xxxxxxx '
159 + 'xx xxxxxx xxxxxx xxxxxx xx xxxxxxx xxx xxx ${0} xx x xxxxxxxx xxxxx'.xxxxxx(xxxxxx_xxxxxx_xxx))
165 'xxxxxxxxxxxxxxx' : xxxxxx_xxxxx_xxxx,
166 # 'xxxxxxxxxxxxxxxxxxxxxxx'
167 # 'xxxxxxxxxxxxxxxxxxxxxx'
168 # 'xxxxxxxxxxxxxxxxxx'
169 # 'xxxxxxxxxxxxxxxxx'
170 'xxxxxxxxxx' : xxxxx_xxxxx,
174 def xxxx_xxx_xx_xxxxxxxxxx_xxxx_xxxxxxxxx(xxxx):
181 xxxxxx={'xxxxxx 1' : xxxxxx(xxxx='xxxxxx 1', xxxxxx=600.0)},
182 xxxxxxxx_xxxxxxx=0.0,
189 xxxxxx={'xxxxxx 1' : xxxxxx(xxxx='xxxxxx 1', xxxxxx=200.0)},
190 xxxxxxxx_xxxxxxx=0.0,
198 'xxxxx006': ['xxx-xxx xxxxx3xxxx1xx2xxxxxxxxxxxxxx0xx6xxxxxxxxxx2xxxxxx9xxxxxxxxxx0xxxxx1xxx2x/xx9xx6+x+xxxxxxxxxxxxxx4xxxxxxxxxxxxxxxxxxxxx43xxx2xx2x4x++xxx6xxxxxxxxx+xxxxx/xx9x+xxxxxxxxxxxxxx8x15xxxxxxxxxxxxxxxxx82xx/xxxxxxxxxxxxxx/x5xxxxxxxxxxxxxx6xxxxxx74x4/xxx4x+xxxxxxxxx2xxxxxxxx87xxxxx4xxxxxxxx3xx0xxxxx4xxx1xx9xx5xxxxxxx/xxxxx5xx6xx4xxxx1x/x2xxxxxxxxxxxx64xxxxxxx1x0xx5xxxxxxxxxxxxxx== xxxxx000 xxxxxxxxxx\n',
199 'xxx-xxx xxxxx3xxxx1xx2xxxxxxxxxxxxxx6xxxxxxxxxxxxxx9xxxxxxxxxxxxx3xxx9xxxxxxxxxxxxxxxx0xxxxxxxxxxxxxxxxx2xxxx2xxx6xxxxx/xx54xxxxxxxxx4xxx3xxxxxx9xx3xxxxx39xxxxxxxxx5xx91xxxx7xxxxxx8xxxxxxxxxxxxxxxx9xxx93xxxxxxxxxxxxxxxxx7xxx8xx8xx4/x1xxxxx1x3xxxxxxxxxxxxx3xxxxxx9xx4xx4x7xxxxxxxxxxxxx1xxxxxxxxx7xxxxxxxxxxxxxx4xx6xxxxxxxxx9xxx7xxxx2xxxxxxxxxxxxxxxxxxxxxx8xxxxxxxxxxxxxxxxxxxx6xx== xxxxx010 xxxxxxxxxx\n'],
200 'xxxxx016': ['xxx-xxx xxxxx3xxxx1xx2xxxxxxxxxxxxxx0xx6xxxxxxxxxx2xxxxxx9xxxxxxxxxx0xxxxx1xxx2x/xx9xx6+x+xxxxxxxxxxxxxx4xxxxxxxxxxxxxxxxxxxxx43xxx2xx2x4x++xxx6xxxxxxxxx+xxxxx/xx9x+xxxxxxxxxxxxxx8x15xxxxxxxxxxxxxxxxx82xx/xxxxxxxxxxxxxx/x5xxxxxxxxxxxxxx6xxxxxx74x4/xxx4x+xxxxxxxxx2xxxxxxxx87xxxxx4xxxxxxxx3xx0xxxxx4xxx1xx9xx5xxxxxxx/xxxxx5xx6xx4xxxx1x/x2xxxxxxxxxxxx64xxxxxxx1x0xx5xxxxxxxxxxxxxx== xxxxx000 xxxxxxxxxx\n',
201 'xxx-xxx xxxxx3xxxx1xx2xxxxxxxxxxxxxx6xxxxxxxxxxxxxx9xxxxxxxxxxxxx3xxx9xxxxxxxxxxxxxxxx0xxxxxxxxxxxxxxxxx2xxxx2xxx6xxxxx/xx54xxxxxxxxx4xxx3xxxxxx9xx3xxxxx39xxxxxxxxx5xx91xxxx7xxxxxx8xxxxxxxxxxxxxxxx9xxx93xxxxxxxxxxxxxxxxx7xxx8xx8xx4/x1xxxxx1x3xxxxxxxxxxxxx3xxxxxx9xx4xx4x7xxxxxxxxxxxxx1xxxxxxxxx7xxxxxxxxxxxxxx4xx6xxxxxxxxx9xxx7xxxx2xxxxxxxxxxxxxxxxxxxxxx8xxxxxxxxxxxxxxxxxxxx6xx== xxxxx010 xxxxxxxxxx\n']
206 'xxxx xxx xxxxxxxx_xxxx xx "xxxxxxxxxx".'
207 '\n xxx: xxxxxx xxxxxxxx_xxxx=xxxxxxxxxx'
208 ) # xxxx xxxxxxxxxx xxxx xx xxxx xx xxx xxxxxxxx xxxxxx xxxxx.
210 some_tuple = ("some string", "some string" " which should be joined")
212 some_commented_string = (
213 "This string is long but not so long that it needs hahahah toooooo be so greatttt" # This comment gets thrown to the top.
214 " {} that I just can't think of any more good words to say about it at"
215 " allllllllllll".format("ha") # comments here are fine
218 some_commented_string = (
219 "This string is long but not so long that it needs hahahah toooooo be so greatttt" # But these
220 " {} that I just can't think of any more good words to say about it at" # comments will stay
221 " allllllllllll".format("ha") # comments here are fine
224 lpar_and_rpar_have_comments = func_call( # LPAR Comment
225 "Long really ridiculous type of string that shouldn't really even exist at all. I mean commmme onnn!!!", # Comma Comment
229 f"sudo -E deluge-console info --detailed --sort-reverse=time_added "
230 f"{'' if ID is None else ID} | perl -nE 'print if /^{field}:/'"
233 cmd_fstring = f"sudo -E deluge-console info --detailed --sort-reverse=time_added {'' if ID is None else ID} | perl -nE 'print if /^{field}:/'"
235 cmd_fstring = f"sudo -E deluge-console info --detailed --sort-reverse=time_added {'{{}}' if ID is None else ID} | perl -nE 'print if /^{field}:/'"
237 cmd_fstring = f"sudo -E deluge-console info --detailed --sort-reverse=time_added {{'' if ID is None else ID}} | perl -nE 'print if /^{field}:/'"
239 fstring = f"This string really doesn't need to be an {{{{fstring}}}}, but this one most certainly, absolutely {does}."
242 f"We have to remember to escape {braces}."
251 f"This string ({string_leaf.value}) appears to be pointless (i.e. has"
256 user_regex = _lazy_re_compile(
257 r"(^[-!#$%&'*+/=?^_`{}|~0-9A-Z]+(\.[-!#$%&'*+/=?^_`{}|~0-9A-Z]+)*\Z" # dot-atom
258 r'|^"([\001-\010\013\014\016-\037!#-\[\]-\177]|\\[\001-\011\013\014\016-\177])*"\Z)', # quoted-string
262 user_regex = _lazy_re_compile(
263 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" # dot-atom
264 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', # quoted-string
269 user_regex = _lazy_re_compile(
270 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" # dot-atom
271 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', # quoted-string
278 if not hasattr(module, name):
280 "Could not find object %s in %s.\n"
281 "Please note that you cannot serialize things like inner "
282 "classes. Please move the object into the main module "
283 "body to use migrations.\n"
284 "For more information, see "
285 "https://docs.djangoproject.com/en/%s/topics/migrations/#serializing-values"
286 % (name, module_name, get_docs_version()))
291 if not hasattr(module, name):
293 "Could not find object %s in %s.\nPlease note that you cannot serialize things like inner classes. Please move the object into the main module body to use migrations.\nFor more information, see https://docs.djangoproject.com/en/%s/topics/migrations/#serializing-values"
294 % (name, module_name, get_docs_version()))
297 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
298 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
299 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
300 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
303 class Step(StepBase):
305 self.cmd = 'SR AAAA-CORRECT NAME IS {last_name} {first_name}{middle_name} {title}/P{passenger_association}'.format(
307 first_name=first_name,
308 middle_name=middle_name,
310 passenger_association=passenger_association,
313 xxxxxxx_xxxxxx_xxxxxxx = xxx(
317 '((x.aaaaaaaaa = "xxxxxx.xxxxxxxxxxxxxxxxxxxxx") || (x.xxxxxxxxx = "xxxxxxxxxxxx")) && '
318 # xxxxx xxxxxxxxxxxx xxxx xxx (xxxxxxxxxxxxxxxx) xx x xxxxxxxxx xx xxxxxx.
319 "(x.bbbbbbbbbbbb.xxx != "
320 '"xxx:xxx:xxx::cccccccccccc:xxxxxxx-xxxx/xxxxxxxxxxx/xxxxxxxxxxxxxxxxx") && '
326 if __name__ == "__main__":
327 for i in range(4, 8):
329 r"for pid in $(ps aux | grep paster | grep -v grep | grep '\-%d' | awk '{print $2}'); do kill $pid; done"
341 c_float(val[0][0] / val[0][1]).value
342 == c_float(value[0][0] / value[0][1]).value
343 ), "%s didn't roundtrip" % tag
345 class xxxxxxxxxxxxxxxxxxxxx(xxxx.xxxxxxxxxxxxx):
346 def xxxxxxx_xxxxxx(xxxx):
347 assert xxxxxxx_xxxx in [
348 x.xxxxx.xxxxxx.xxxxx.xxxxxx,
349 x.xxxxx.xxxxxx.xxxxx.xxxx,
350 ], ("xxxxxxxxxxx xxxxxxx xxxx (xxxxxx xxxx) %x xxx xxxxx" % xxxxxxx_xxxx)
354 ] = "test" # set some Thrift field to non-None in the struct aa bb cc dd ee
357 "asdf_hjkl_jkl": re.compile(
358 r"(?<!([0-9]\ ))(?<=(^|\ ))([A-Z]+(\ )?|[0-9](\ )|[a-z](\ )){4,7}([A-Z]|[0-9]|[a-z])($|\b)(?!(\ ?([0-9]\ )|(\.)))"
362 RE_TWO_BACKSLASHES = {
363 "asdf_hjkl_jkl": re.compile(
364 r"(?<!([0-9]\ ))(?<=(^|\ ))([A-Z]+(\ )?|[0-9](\ )|[a-z](\\ )){4,7}([A-Z]|[0-9]|[a-z])($|\b)(?!(\ ?([0-9]\ )|(\.)))"
368 RE_THREE_BACKSLASHES = {
369 "asdf_hjkl_jkl": re.compile(
370 r"(?<!([0-9]\ ))(?<=(^|\ ))([A-Z]+(\ )?|[0-9](\ )|[a-z](\\\ )){4,7}([A-Z]|[0-9]|[a-z])($|\b)(?!(\ ?([0-9]\ )|(\.)))"
374 # We do NOT split on f-string expressions.
375 print(f"Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam. {[f'{i}' for i in range(10)]}")
376 x = f"This is a long string which contains an f-expr that should not split {{{[i for i in range(5)]}}}."
378 # The parens should NOT be removed in this case.
380 "my very long string that should get formatted if I'm careful to make sure it goes"
381 " over 88 characters which it has now"
384 # The parens should NOT be removed in this case.
386 "my very long string that should get formatted if I'm careful to make sure it goes over 88 characters which"
390 # The parens should NOT be removed in this case.
392 "my very long string"
393 " that should get formatted"
394 " if I'm careful to make sure"
395 " it goes over 88 characters which"
400 def _legacy_listen_examples():
402 " \"listen for the '%(event_name)s' event\"\n"
403 "\n # ... (event logic logic logic) ...\n"
413 for candidate in CANDIDATES:
415 "**{candidate.object_type} {candidate.rev}**"
416 " - {candidate.description}\n"
421 f"{f'{humanize_number(pos)}.': <{pound_len+2}} "
422 f"{balance: <{bal_len + 5}} "
423 f"<<{author.display_name}>>\n"
426 assert str(suffix_arr) == (
427 "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
428 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
429 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
431 assert str(suffix_arr) != (
432 "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
433 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
434 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
436 assert str(suffix_arr) <= (
437 "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
438 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
439 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
441 assert str(suffix_arr) >= (
442 "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
443 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
444 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
446 assert str(suffix_arr) < (
447 "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
448 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
449 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
451 assert str(suffix_arr) > (
452 "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
453 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
454 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
456 assert str(suffix_arr) in "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', 'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', 'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
457 assert str(suffix_arr) not in "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', 'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', 'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
459 f"1. Go to Google Developers Console and log in with your Google account."
460 "(https://console.developers.google.com/)"
461 "2. You should be prompted to create a new project (name does not matter)."
462 "3. Click on Enable APIs and Services at the top."
463 "4. In the list of APIs choose or search for YouTube Data API v3 and "
464 "click on it. Choose Enable."
465 "5. Click on Credentials on the left navigation bar."
466 "6. Click on Create Credential at the top."
467 '7. At the top click the link for "API key".'
468 "8. No application restrictions are needed. Click Create at the bottom."
469 "9. You now have a key to add to `{prefix}set api youtube api_key`"
472 f"1. Go to Google Developers Console and log in with your Google account."
473 "(https://console.developers.google.com/)"
474 "2. You should be prompted to create a new project (name does not matter)."
475 f"3. Click on Enable APIs and Services at the top."
476 "4. In the list of APIs choose or search for YouTube Data API v3 and "
477 "click on it. Choose Enable."
478 f"5. Click on Credentials on the left navigation bar."
479 "6. Click on Create Credential at the top."
480 '7. At the top click the link for "API key".'
481 "8. No application restrictions are needed. Click Create at the bottom."
482 "9. You now have a key to add to `{prefix}set api youtube api_key`"
485 f"1. Go to Google Developers Console and log in with your Google account."
486 "(https://console.developers.google.com/)"
487 "2. You should be prompted to create a new project (name does not matter)."
488 f"3. Click on Enable APIs and Services at the top."
489 "4. In the list of APIs choose or search for YouTube Data API v3 and "
490 "click on it. Choose Enable."
491 f"5. Click on Credentials on the left navigation bar."
492 "6. Click on Create Credential at the top."
493 '7. At the top click the link for "API key".'
494 "8. No application restrictions are needed. Click Create at the bottom."
495 f"9. You now have a key to add to `{prefix}set api youtube api_key`"
498 # It shouldn't matter if the string prefixes are capitalized.
500 F"{F'{humanize_number(pos)}.': <{pound_len+2}} "
501 F"{balance: <{bal_len + 5}} "
502 F"<<{author.display_name}>>\n"
506 F"We have to remember to escape {braces}."
511 welcome_to_programming = R"hello," R" world!"
513 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."
515 x = F"This is a long string which contains an f-expr that should not split {{{[i for i in range(5)]}}}."
518 "\N{BLACK RIGHT-POINTING TRIANGLE WITH DOUBLE VERTICAL BAR}\N{VARIATION SELECTOR-16}"
521 xxxxxx_xxx_xxxx_xx_xxxxx_xxxxxxxx_xxxxxxxx_xxxxxxxxxx_xxxx_xxxx_xxxxx = xxxx.xxxxxx.xxxxxxxxx.xxxxxxxxxxxxxxxxxxxx(
523 "x3_xxxxxxxx": "xxx3_xxxxx_xxxxxxxx_xxxxxxxx_xxxxxxxxxx_xxxxxxxx_xxxxxx_xxxxxxx",
527 # Regression test for https://github.com/psf/black/issues/3117.
529 "something_something":
530 r"Lorem ipsum dolor sit amet, an sed convenire eloquentiam \t"
531 r"signiferumque, duo ea vocibus consetetur scriptorem. Facer \t",
534 # Regression test for https://github.com/psf/black/issues/3459.
536 empty_str_as_first_split=''
537 f'xxxxxxx {xxxxxxxxxx} xxx xxxxxxxxxx xxxxx xxx xxx xx '
538 'xxxxx xxxxxxxxx xxxxxxx, xxx xxxxxxxxxxx xxx xxxxx. '
539 f'xxxxxxxxxxxxx xxxx xx xxxxxxxxxx. xxxxx: {x.xxx}',
540 empty_u_str_as_first_split=u''
541 f'xxxxxxx {xxxxxxxxxx} xxx xxxxxxxxxx xxxxx xxx xxx xx '
542 'xxxxx xxxxxxxxx xxxxxxx, xxx xxxxxxxxxxx xxx xxxxx. '
543 f'xxxxxxxxxxxxx xxxx xx xxxxxxxxxx. xxxxx: {x.xxx}',
552 result = type(message)("")
555 # Don't merge multiline (e.g. triple-quoted) strings.
558 """SELECT xxxxxxxxxxxxxxxxxxxx(xxx)"""
559 """ FROM xxxxxxxxxxxxxxxx WHERE xxxxxxxxxx AND xxx <> xxxxxxxxxxxxxx()"""
563 # There was a bug where tuples were being identified as long strings.
577 stupid_format_method_bug = (
578 "Some really long string that just so happens to be the {} {} to force the 'format'"
579 " method to hang over the line length boundary. This is pretty annoying.".format(
588 "This is a regression test. xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx"
589 " xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx xxx"
590 " xxxx.".format("xxxxxxxxxx", "xxxxxx", "xxxxxxxxxx")
598 "xxx_xxxxxxxxxx(xxxxx={}, xxxx={}, xxxxx, xxxx_xxxx_xxxxxxxxxx={})"
599 .format(xxxxx, xxxx, xxxx_xxxx_xxxxxxxxxx),
610 "[{}]: xxx_xxxxxxxxxx(xxxxx={}, xxxx={}, xxxxx={}"
611 " xxxx_xxxx_xxxxxxxxxx={}, xxxx={})".format(
612 xxxx._xxxxxxxxxxxxxx, xxxxx, xxxx, xxxx_xxxx_xxxxxxxxxx, xxxxxxx
621 for xxx_xxxx, _xxx_xxx, _xxx_xxxxx, xxx_xxxx in xxxx:
623 assert ("x" in xxx) or (xxx in xxx_xxx_xxxxx), (
624 "{0} xxxxxxx xx {1}, xxx {1} xx xxx xx xxxx xx xxx xxxx: xxx xxxx {2}"
625 .format(xxx_xxxx, xxx, xxxxxx.xxxxxxx(xxx_xxx_xxxxx))
630 def disappearing_comment():
632 ( # xx -x xxxxxxx xx xxx xxxxxxx.
633 "{{xxx_xxxxxxxxxx_xxxxxxxx}} xxx xxxx {} {{xxxx}} >&2".format(
635 if xxxxx.xx_xxxxxxxxxx
636 else ( # Disappearing Comment
637 "--xxxxxxx --xxxxxx=x --xxxxxx-xxxxx=xxxxxx"
638 " --xxxxxx-xxxx=xxxxxxxxxxx.xxx"
652 "@xxxxxx '{xxxx_xxx}\t' > {xxxxxx_xxxx}.xxxxxxx;"
653 "{xxxx_xxx} >> {xxxxxx_xxxx}.xxxxxxx 2>&1; xx=$$?;"
655 xxxx_xxx=xxxx_xxxxxxx,
656 xxxxxx_xxxx=xxxxxxx + "/" + xxxx_xxx_xxxx,
657 x=xxx_xxxxx_xxxxx_xxx,
665 func_call_where_string_arg_has_method_call_and_bad_parens(
666 "A long string with {}. This string is so long that it is ridiculous. It can't fit"
667 " on one line at alllll.".format("formatting"),
670 func_call_where_string_arg_has_old_fmt_and_bad_parens(
671 "A long string with {}. This string is so long that it is ridiculous. It can't fit"
672 " on one line at alllll." % "formatting",
675 func_call_where_string_arg_has_old_fmt_and_bad_parens(
676 "A long string with {}. This {} is so long that it is ridiculous. It can't fit on"
677 " one line at alllll." % ("formatting", "string"),
685 "xxxxxxxxxx xxxx xx xxxxxx(%x) xx %x xxxx xx xxx %x.xx"
686 % (len(self) + 1, xxxx.xxxxxxxxxx, xxxx.xxxxxxxxxx)
687 + " %.3f (%s) to %.3f (%s).\n"
690 xxxx.xxxxxxxxxxxxxx(xxxx.xxxxxxxxx),
692 xxxx.xxxxxxxxxxxxxx(xx),
702 "xx {xxxxxxxxxxx}/xxxxxxxxxxx.xxx xxxx.xxx && xxxxxx -x "
703 '"xxxx xxxxxxx xxxxxx xxxx; xxxx xxxxxx_xxxxx xxxxxx xxxx; '
704 "xxxx.xxxx_xxxxxx(['xxxx.xxx'], xxxx.xxxxxxx().xxxxxxxxxx)\" "
715 "xx {xxxxxxxxxxx}/xxxxxxxxxxx.xxx xxxx.xxx && xxxxxx -x "
716 "xxxx, ('xxxxxxx xxxxxx xxxx, xxxx') xxxxxx_xxxxx xxxxxx xxxx; "
717 "xxxx.xxxx_xxxxxx(['xxxx.xxx'], xxxx.xxxxxxx().xxxxxxxxxx)\" "
726 "xxxx xxxxxxx xxxxxxxxx -x xxx -x /xxx/{0} -x xxx,xxx -xx {1} -xx {1} -xx"
727 " xxx=xxx_xxxx,xxx_xx,xxx_xxx,xxx_xxxx,xxx_xx,xxx_xxx | xxxxxx -x xxxxxxxx -x"
731 "xxxx xxxxxxx xxxxxxxxx -x xxx -x /xxx/{0} -x xxx,xxx -xx {1} -xx {1} -xx"
732 " xxx=xxx_xxxx_xxx_xxxx,xxx_xx_xxx_xxxx,xxx_xxxx_xxx_xxxx,xxx_xx_xxxx_xxxx,xxx_xxx_xxxx,xxx_xxx_xxxx"
733 " xxxx=xxx | xxxxxx -x xxxxxxxx -x xxxxxxxx -x"
742 "xxx xxxxxx xxx xxxxxxxxx.xx xx xxxxxxxx. xxx xxxxxxxxxxxxx.xx"
744 + "xx xxxxxx xxxxxx xxxxxx xx xxxxxxx xxx xxx ${0} xx x xxxxxxxx xxxxx"
745 .xxxxxx(xxxxxx_xxxxxx_xxx)
753 "xxxxxxxxxxxxxxx": xxxxxx_xxxxx_xxxx,
754 # 'xxxxxxxxxxxxxxxxxxxxxxx'
755 # 'xxxxxxxxxxxxxxxxxxxxxx'
756 # 'xxxxxxxxxxxxxxxxxx'
757 # 'xxxxxxxxxxxxxxxxx'
758 "xxxxxxxxxx": xxxxx_xxxxx,
763 def xxxx_xxx_xx_xxxxxxxxxx_xxxx_xxxxxxxxx(xxxx):
770 xxxxxx={"xxxxxx 1": xxxxxx(xxxx="xxxxxx 1", xxxxxx=600.0)},
771 xxxxxxxx_xxxxxxx=0.0,
778 xxxxxx={"xxxxxx 1": xxxxxx(xxxx="xxxxxx 1", xxxxxx=200.0)},
779 xxxxxxxx_xxxxxxx=0.0,
791 " xxxxx3xxxx1xx2xxxxxxxxxxxxxx0xx6xxxxxxxxxx2xxxxxx9xxxxxxxxxx0xxxxx1xxx2x/xx9xx6+x+xxxxxxxxxxxxxx4xxxxxxxxxxxxxxxxxxxxx43xxx2xx2x4x++xxx6xxxxxxxxx+xxxxx/xx9x+xxxxxxxxxxxxxx8x15xxxxxxxxxxxxxxxxx82xx/xxxxxxxxxxxxxx/x5xxxxxxxxxxxxxx6xxxxxx74x4/xxx4x+xxxxxxxxx2xxxxxxxx87xxxxx4xxxxxxxx3xx0xxxxx4xxx1xx9xx5xxxxxxx/xxxxx5xx6xx4xxxx1x/x2xxxxxxxxxxxx64xxxxxxx1x0xx5xxxxxxxxxxxxxx=="
792 " xxxxx000 xxxxxxxxxx\n"
796 " xxxxx3xxxx1xx2xxxxxxxxxxxxxx6xxxxxxxxxxxxxx9xxxxxxxxxxxxx3xxx9xxxxxxxxxxxxxxxx0xxxxxxxxxxxxxxxxx2xxxx2xxx6xxxxx/xx54xxxxxxxxx4xxx3xxxxxx9xx3xxxxx39xxxxxxxxx5xx91xxxx7xxxxxx8xxxxxxxxxxxxxxxx9xxx93xxxxxxxxxxxxxxxxx7xxx8xx8xx4/x1xxxxx1x3xxxxxxxxxxxxx3xxxxxx9xx4xx4x7xxxxxxxxxxxxx1xxxxxxxxx7xxxxxxxxxxxxxx4xx6xxxxxxxxx9xxx7xxxx2xxxxxxxxxxxxxxxxxxxxxx8xxxxxxxxxxxxxxxxxxxx6xx=="
797 " xxxxx010 xxxxxxxxxx\n"
803 " xxxxx3xxxx1xx2xxxxxxxxxxxxxx0xx6xxxxxxxxxx2xxxxxx9xxxxxxxxxx0xxxxx1xxx2x/xx9xx6+x+xxxxxxxxxxxxxx4xxxxxxxxxxxxxxxxxxxxx43xxx2xx2x4x++xxx6xxxxxxxxx+xxxxx/xx9x+xxxxxxxxxxxxxx8x15xxxxxxxxxxxxxxxxx82xx/xxxxxxxxxxxxxx/x5xxxxxxxxxxxxxx6xxxxxx74x4/xxx4x+xxxxxxxxx2xxxxxxxx87xxxxx4xxxxxxxx3xx0xxxxx4xxx1xx9xx5xxxxxxx/xxxxx5xx6xx4xxxx1x/x2xxxxxxxxxxxx64xxxxxxx1x0xx5xxxxxxxxxxxxxx=="
804 " xxxxx000 xxxxxxxxxx\n"
808 " xxxxx3xxxx1xx2xxxxxxxxxxxxxx6xxxxxxxxxxxxxx9xxxxxxxxxxxxx3xxx9xxxxxxxxxxxxxxxx0xxxxxxxxxxxxxxxxx2xxxx2xxx6xxxxx/xx54xxxxxxxxx4xxx3xxxxxx9xx3xxxxx39xxxxxxxxx5xx91xxxx7xxxxxx8xxxxxxxxxxxxxxxx9xxx93xxxxxxxxxxxxxxxxx7xxx8xx8xx4/x1xxxxx1x3xxxxxxxxxxxxx3xxxxxx9xx4xx4x7xxxxxxxxxxxxx1xxxxxxxxx7xxxxxxxxxxxxxx4xx6xxxxxxxxx9xxx7xxxx2xxxxxxxxxxxxxxxxxxxxxx8xxxxxxxxxxxxxxxxxxxx6xx=="
809 " xxxxx010 xxxxxxxxxx\n"
816 xxx_xxx = ( # xxxx xxxxxxxxxx xxxx xx xxxx xx xxx xxxxxxxx xxxxxx xxxxx.
817 'xxxx xxx xxxxxxxx_xxxx xx "xxxxxxxxxx".\n xxx: xxxxxx xxxxxxxx_xxxx=xxxxxxxxxx'
821 some_tuple = ("some string", "some string which should be joined")
823 some_commented_string = ( # This comment gets thrown to the top.
824 "This string is long but not so long that it needs hahahah toooooo be so greatttt"
825 " {} that I just can't think of any more good words to say about it at"
826 " allllllllllll".format("ha") # comments here are fine
829 some_commented_string = (
830 "This string is long but not so long that it needs hahahah toooooo be so greatttt" # But these
831 " {} that I just can't think of any more good words to say about it at" # comments will stay
832 " allllllllllll".format("ha") # comments here are fine
835 lpar_and_rpar_have_comments = func_call( # LPAR Comment
837 "Long really ridiculous type of string that shouldn't really even exist at all."
838 " I mean commmme onnn!!!"
843 "sudo -E deluge-console info --detailed --sort-reverse=time_added "
844 f"{'' if ID is None else ID} | perl -nE 'print if /^{field}:/'"
848 "sudo -E deluge-console info --detailed --sort-reverse=time_added"
849 f" {'' if ID is None else ID} | perl -nE 'print if /^{field}:/'"
853 "sudo -E deluge-console info --detailed --sort-reverse=time_added"
854 f" {'{{}}' if ID is None else ID} | perl -nE 'print if /^{field}:/'"
858 "sudo -E deluge-console info --detailed --sort-reverse=time_added {'' if ID is"
859 f" None else ID}} | perl -nE 'print if /^{field}:/'"
863 "This string really doesn't need to be an {{fstring}}, but this one most"
864 f" certainly, absolutely {does}."
867 fstring = f"We have to remember to escape {braces}. Like {{these}}. But not {this}."
874 f"This string ({string_leaf.value}) appears to be pointless (i.e. has"
880 user_regex = _lazy_re_compile(
881 r"(^[-!#$%&'*+/=?^_`{}|~0-9A-Z]+(\.[-!#$%&'*+/=?^_`{}|~0-9A-Z]+)*\Z" # dot-atom
882 r'|^"([\001-\010\013\014\016-\037!#-\[\]-\177]|\\[\001-\011\013\014\016-\177])*"\Z)', # quoted-string
888 user_regex = _lazy_re_compile(
889 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" # dot-atom
890 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", # quoted-string
896 user_regex = _lazy_re_compile(
897 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" # dot-atom
898 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", # quoted-string
906 if not hasattr(module, name):
908 "Could not find object %s in %s.\n"
909 "Please note that you cannot serialize things like inner "
910 "classes. Please move the object into the main module "
911 "body to use migrations.\n"
912 "For more information, see "
913 "https://docs.djangoproject.com/en/%s/topics/migrations/#serializing-values"
914 % (name, module_name, get_docs_version())
921 if not hasattr(module, name):
923 "Could not find object %s in %s.\nPlease note that you cannot"
924 " serialize things like inner classes. Please move the object into"
925 " the main module body to use migrations.\nFor more information,"
926 " see https://docs.djangoproject.com/en/%s/topics/migrations/#serializing-values"
927 % (name, module_name, get_docs_version())
932 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
933 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
934 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
935 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
939 class Step(StepBase):
942 "SR AAAA-CORRECT NAME IS {last_name} {first_name}{middle_name}"
943 " {title}/P{passenger_association}".format(
945 first_name=first_name,
946 middle_name=middle_name,
948 passenger_association=passenger_association,
953 xxxxxxx_xxxxxx_xxxxxxx = xxx(
957 '((x.aaaaaaaaa = "xxxxxx.xxxxxxxxxxxxxxxxxxxxx") || (x.xxxxxxxxx ='
958 ' "xxxxxxxxxxxx")) && '
959 # xxxxx xxxxxxxxxxxx xxxx xxx (xxxxxxxxxxxxxxxx) xx x xxxxxxxxx xx xxxxxx.
960 "(x.bbbbbbbbbbbb.xxx != "
961 '"xxx:xxx:xxx::cccccccccccc:xxxxxxx-xxxx/xxxxxxxxxxx/xxxxxxxxxxxxxxxxx") && '
967 if __name__ == "__main__":
968 for i in range(4, 8):
970 r"for pid in $(ps aux | grep paster | grep -v grep | grep '\-%d' | awk"
971 r" '{print $2}'); do kill $pid; done" % (i)
983 c_float(val[0][0] / val[0][1]).value
984 == c_float(value[0][0] / value[0][1]).value
985 ), "%s didn't roundtrip" % tag
988 class xxxxxxxxxxxxxxxxxxxxx(xxxx.xxxxxxxxxxxxx):
989 def xxxxxxx_xxxxxx(xxxx):
990 assert xxxxxxx_xxxx in [
991 x.xxxxx.xxxxxx.xxxxx.xxxxxx,
992 x.xxxxx.xxxxxx.xxxxx.xxxx,
994 "xxxxxxxxxxx xxxxxxx xxxx (xxxxxx xxxx) %x xxx xxxxx" % xxxxxxx_xxxx
998 value.__dict__[key] = (
999 "test" # set some Thrift field to non-None in the struct aa bb cc dd ee
1002 RE_ONE_BACKSLASH = {
1003 "asdf_hjkl_jkl": re.compile(
1004 r"(?<!([0-9]\ ))(?<=(^|\ ))([A-Z]+(\ )?|[0-9](\ )|[a-z](\ )){4,7}([A-Z]|[0-9]|[a-z])($|\b)(?!(\ ?([0-9]\ )|(\.)))"
1008 RE_TWO_BACKSLASHES = {
1009 "asdf_hjkl_jkl": re.compile(
1010 r"(?<!([0-9]\ ))(?<=(^|\ ))([A-Z]+(\ )?|[0-9](\ )|[a-z](\\"
1011 r" )){4,7}([A-Z]|[0-9]|[a-z])($|\b)(?!(\ ?([0-9]\ )|(\.)))"
1015 RE_THREE_BACKSLASHES = {
1016 "asdf_hjkl_jkl": re.compile(
1017 r"(?<!([0-9]\ ))(?<=(^|\ ))([A-Z]+(\ )?|[0-9](\ )|[a-z](\\\ )){4,7}([A-Z]|[0-9]|[a-z])($|\b)(?!(\ ?([0-9]\ )|(\.)))"
1021 # We do NOT split on f-string expressions.
1023 "Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam."
1024 f" {[f'{i}' for i in range(10)]}"
1027 "This is a long string which contains an f-expr that should not split"
1028 f" {{{[i for i in range(5)]}}}."
1031 # The parens should NOT be removed in this case.
1033 "my very long string that should get formatted if I'm careful to make sure it goes"
1034 " over 88 characters which it has now"
1037 # The parens should NOT be removed in this case.
1039 "my very long string that should get formatted if I'm careful to make sure it goes"
1040 " over 88 characters which it has now"
1043 # The parens should NOT be removed in this case.
1045 "my very long string"
1046 " that should get formatted"
1047 " if I'm careful to make sure"
1048 " it goes over 88 characters which"
1053 def _legacy_listen_examples():
1055 " \"listen for the '%(event_name)s' event\"\n"
1056 "\n # ... (event logic logic logic) ...\n"
1064 async def foo(self):
1066 for candidate in CANDIDATES:
1068 "**{candidate.object_type} {candidate.rev}**"
1069 " - {candidate.description}\n"
1074 f"{f'{humanize_number(pos)}.': <{pound_len+2}} "
1075 f"{balance: <{bal_len + 5}} "
1076 f"<<{author.display_name}>>\n"
1081 == "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
1082 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
1083 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
1087 != "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
1088 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
1089 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
1093 <= "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
1094 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
1095 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
1099 >= "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
1100 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
1101 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
1105 < "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
1106 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
1107 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
1111 > "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', "
1112 "'grykangaroo$', 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', "
1113 "'o$', 'oo$', 'roo$', 'rykangaroo$', 'ykangaroo$']"
1117 in "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', 'grykangaroo$',"
1118 " 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', 'o$', 'oo$', 'roo$', 'rykangaroo$',"
1123 not in "['$', 'angaroo$', 'angrykangaroo$', 'aroo$', 'garoo$', 'grykangaroo$',"
1124 " 'kangaroo$', 'ngaroo$', 'ngrykangaroo$', 'o$', 'oo$', 'roo$',"
1125 " 'rykangaroo$', 'ykangaroo$']"
1128 f"1. Go to Google Developers Console and log in with your Google account."
1129 f"(https://console.developers.google.com/)"
1130 f"2. You should be prompted to create a new project (name does not matter)."
1131 f"3. Click on Enable APIs and Services at the top."
1132 f"4. In the list of APIs choose or search for YouTube Data API v3 and "
1133 f"click on it. Choose Enable."
1134 f"5. Click on Credentials on the left navigation bar."
1135 f"6. Click on Create Credential at the top."
1136 f'7. At the top click the link for "API key".'
1137 f"8. No application restrictions are needed. Click Create at the bottom."
1138 f"9. You now have a key to add to `{{prefix}}set api youtube api_key`"
1141 f"1. Go to Google Developers Console and log in with your Google account."
1142 f"(https://console.developers.google.com/)"
1143 f"2. You should be prompted to create a new project (name does not matter)."
1144 f"3. Click on Enable APIs and Services at the top."
1145 f"4. In the list of APIs choose or search for YouTube Data API v3 and "
1146 f"click on it. Choose Enable."
1147 f"5. Click on Credentials on the left navigation bar."
1148 f"6. Click on Create Credential at the top."
1149 f'7. At the top click the link for "API key".'
1150 f"8. No application restrictions are needed. Click Create at the bottom."
1151 f"9. You now have a key to add to `{{prefix}}set api youtube api_key`"
1154 "1. Go to Google Developers Console and log in with your Google account."
1155 "(https://console.developers.google.com/)"
1156 "2. You should be prompted to create a new project (name does not matter)."
1157 "3. Click on Enable APIs and Services at the top."
1158 "4. In the list of APIs choose or search for YouTube Data API v3 and "
1159 "click on it. Choose Enable."
1160 "5. Click on Credentials on the left navigation bar."
1161 "6. Click on Create Credential at the top."
1162 '7. At the top click the link for "API key".'
1163 "8. No application restrictions are needed. Click Create at the bottom."
1164 f"9. You now have a key to add to `{prefix}set api youtube api_key`"
1167 # It shouldn't matter if the string prefixes are capitalized.
1169 f"{F'{humanize_number(pos)}.': <{pound_len+2}} "
1170 f"{balance: <{bal_len + 5}} "
1171 f"<<{author.display_name}>>\n"
1174 fstring = f"We have to remember to escape {braces}. Like {{these}}. But not {this}."
1176 welcome_to_programming = R"hello," R" world!"
1179 f"f-strings definitely make things more {difficult} than they need to be for"
1180 " {black}. But boy they sure are handy. The problem is that some lines will need"
1181 f" to have the 'f' whereas others do not. This {line}, for example, needs one."
1185 "This is a long string which contains an f-expr that should not split"
1186 f" {{{[i for i in range(5)]}}}."
1190 "\N{BLACK RIGHT-POINTING TRIANGLE WITH DOUBLE VERTICAL BAR}\N{VARIATION SELECTOR-16}"
1193 xxxxxx_xxx_xxxx_xx_xxxxx_xxxxxxxx_xxxxxxxx_xxxxxxxxxx_xxxx_xxxx_xxxxx = xxxx.xxxxxx.xxxxxxxxx.xxxxxxxxxxxxxxxxxxxx(
1196 "xxx3_xxxxx_xxxxxxxx_xxxxxxxx_xxxxxxxxxx_xxxxxxxx_xxxxxx_xxxxxxx"
1201 # Regression test for https://github.com/psf/black/issues/3117.
1203 "something_something": (
1204 r"Lorem ipsum dolor sit amet, an sed convenire eloquentiam \t"
1205 r"signiferumque, duo ea vocibus consetetur scriptorem. Facer \t"
1209 # Regression test for https://github.com/psf/black/issues/3459.
1211 empty_str_as_first_split=(
1213 f"xxxxxxx {xxxxxxxxxx} xxx xxxxxxxxxx xxxxx xxx xxx xx "
1214 "xxxxx xxxxxxxxx xxxxxxx, xxx xxxxxxxxxxx xxx xxxxx. "
1215 f"xxxxxxxxxxxxx xxxx xx xxxxxxxxxx. xxxxx: {x.xxx}"
1217 empty_u_str_as_first_split=(
1219 f"xxxxxxx {xxxxxxxxxx} xxx xxxxxxxxxx xxxxx xxx xxx xx "
1220 "xxxxx xxxxxxxxx xxxxxxx, xxx xxxxxxxxxxx xxx xxxxx. "
1221 f"xxxxxxxxxxxxx xxxx xx xxxxxxxxxx. xxxxx: {x.xxx}"