mirror of
https://github.com/python/cpython.git
synced 2025-10-09 16:34:44 +00:00
#13152: Allow to specify a custom tabsize for expanding tabs in textwrap
Patch by John Feuerstein.
This commit is contained in:
parent
d34b57a9a2
commit
d527259f14
4 changed files with 29 additions and 4 deletions
|
@ -107,6 +107,15 @@ indentation from strings that have unwanted whitespace to the left of the text.
|
||||||
expanded to spaces using the :meth:`expandtabs` method of *text*.
|
expanded to spaces using the :meth:`expandtabs` method of *text*.
|
||||||
|
|
||||||
|
|
||||||
|
.. attribute:: tabsize
|
||||||
|
|
||||||
|
(default: ``8``) If :attr:`expand_tabs` is true, then all tab characters
|
||||||
|
in *text* will be expanded to zero or more spaces, depending on the
|
||||||
|
current column and the given tab size.
|
||||||
|
|
||||||
|
.. versionadded:: 3.3
|
||||||
|
|
||||||
|
|
||||||
.. attribute:: replace_whitespace
|
.. attribute:: replace_whitespace
|
||||||
|
|
||||||
(default: ``True``) If true, each whitespace character (as defined by
|
(default: ``True``) If true, each whitespace character (as defined by
|
||||||
|
|
|
@ -91,6 +91,14 @@ What a mess!
|
||||||
result = wrapper.fill(text)
|
result = wrapper.fill(text)
|
||||||
self.check(result, '\n'.join(expect))
|
self.check(result, '\n'.join(expect))
|
||||||
|
|
||||||
|
text = "\tTest\tdefault\t\ttabsize."
|
||||||
|
expect = [" Test default tabsize."]
|
||||||
|
self.check_wrap(text, 80, expect)
|
||||||
|
|
||||||
|
text = "\tTest\tcustom\t\ttabsize."
|
||||||
|
expect = [" Test custom tabsize."]
|
||||||
|
self.check_wrap(text, 80, expect, tabsize=4)
|
||||||
|
|
||||||
def test_fix_sentence_endings(self):
|
def test_fix_sentence_endings(self):
|
||||||
wrapper = TextWrapper(60, fix_sentence_endings=True)
|
wrapper = TextWrapper(60, fix_sentence_endings=True)
|
||||||
|
|
||||||
|
|
|
@ -39,8 +39,11 @@ class TextWrapper:
|
||||||
of wrapped output; also counts towards each line's width.
|
of wrapped output; also counts towards each line's width.
|
||||||
expand_tabs (default: true)
|
expand_tabs (default: true)
|
||||||
Expand tabs in input text to spaces before further processing.
|
Expand tabs in input text to spaces before further processing.
|
||||||
Each tab will become 1 .. 8 spaces, depending on its position in
|
Each tab will become 0 .. 'tabsize' spaces, depending on its position
|
||||||
its line. If false, each tab is treated as a single character.
|
in its line. If false, each tab is treated as a single character.
|
||||||
|
tabsize (default: 8)
|
||||||
|
Expand tabs in input text to 0 .. 'tabsize' spaces, unless
|
||||||
|
'expand_tabs' is false.
|
||||||
replace_whitespace (default: true)
|
replace_whitespace (default: true)
|
||||||
Replace all whitespace characters in the input text by spaces
|
Replace all whitespace characters in the input text by spaces
|
||||||
after tab expansion. Note that if expand_tabs is false and
|
after tab expansion. Note that if expand_tabs is false and
|
||||||
|
@ -100,7 +103,8 @@ class TextWrapper:
|
||||||
fix_sentence_endings=False,
|
fix_sentence_endings=False,
|
||||||
break_long_words=True,
|
break_long_words=True,
|
||||||
drop_whitespace=True,
|
drop_whitespace=True,
|
||||||
break_on_hyphens=True):
|
break_on_hyphens=True,
|
||||||
|
tabsize=8):
|
||||||
self.width = width
|
self.width = width
|
||||||
self.initial_indent = initial_indent
|
self.initial_indent = initial_indent
|
||||||
self.subsequent_indent = subsequent_indent
|
self.subsequent_indent = subsequent_indent
|
||||||
|
@ -110,6 +114,7 @@ class TextWrapper:
|
||||||
self.break_long_words = break_long_words
|
self.break_long_words = break_long_words
|
||||||
self.drop_whitespace = drop_whitespace
|
self.drop_whitespace = drop_whitespace
|
||||||
self.break_on_hyphens = break_on_hyphens
|
self.break_on_hyphens = break_on_hyphens
|
||||||
|
self.tabsize = tabsize
|
||||||
|
|
||||||
|
|
||||||
# -- Private methods -----------------------------------------------
|
# -- Private methods -----------------------------------------------
|
||||||
|
@ -123,7 +128,7 @@ class TextWrapper:
|
||||||
becomes " foo bar baz".
|
becomes " foo bar baz".
|
||||||
"""
|
"""
|
||||||
if self.expand_tabs:
|
if self.expand_tabs:
|
||||||
text = text.expandtabs()
|
text = text.expandtabs(self.tabsize)
|
||||||
if self.replace_whitespace:
|
if self.replace_whitespace:
|
||||||
text = text.translate(self.unicode_whitespace_trans)
|
text = text.translate(self.unicode_whitespace_trans)
|
||||||
return text
|
return text
|
||||||
|
|
|
@ -38,6 +38,9 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #13152: Allow to specify a custom tabsize for expanding tabs in
|
||||||
|
textwrap. Patch by John Feuerstein.
|
||||||
|
|
||||||
- Issue #14721: Send the correct 'Content-length: 0' header when the body is an
|
- Issue #14721: Send the correct 'Content-length: 0' header when the body is an
|
||||||
empty string ''. Initial Patch contributed by Arve Knudsen.
|
empty string ''. Initial Patch contributed by Arve Knudsen.
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue