From 041ec995e5165bc6f7b801a5aa2aba53e6980c1e Mon Sep 17 00:00:00 2001 From: =?utf8?q?=C5=81ukasz=20Langa?= Date: Mon, 4 Jun 2018 16:42:10 -0700 Subject: [PATCH 1/1] Nits --- black.py | 38 ++++++++++---------------- docs/reference/reference_functions.rst | 13 +++++++-- 2 files changed, 26 insertions(+), 25 deletions(-) diff --git a/black.py b/black.py index 19a023c..7138d29 100644 --- a/black.py +++ b/black.py @@ -1,5 +1,4 @@ import asyncio -import pickle from asyncio.base_events import BaseEventLoop from concurrent.futures import Executor, ProcessPoolExecutor from enum import Enum, Flag @@ -10,10 +9,11 @@ import logging from multiprocessing import Manager import os from pathlib import Path +import pickle import re -import tokenize import signal import sys +import tokenize from typing import ( Any, Callable, @@ -57,6 +57,7 @@ CACHE_DIR = Path(user_cache_dir("black", version=__version__)) # types FileContent = str Encoding = str +NewLine = str Depth = int NodeType = int LeafID = int @@ -469,7 +470,7 @@ def format_file_in_place( mode |= FileMode.PYI with open(src, "rb") as buf: - newline, encoding, src_contents = prepare_input(buf.read()) + src_contents, encoding, newline = decode_bytes(buf.read()) try: dst_contents = format_file_contents( src_contents, line_length=line_length, fast=fast, mode=mode @@ -513,7 +514,7 @@ def format_stdin_to_stdout( `line_length`, `fast`, `is_pyi`, and `force_py36` arguments are passed to :func:`format_file_contents`. """ - newline, encoding, src = prepare_input(sys.stdin.buffer.read()) + src, encoding, newline = decode_bytes(sys.stdin.buffer.read()) dst = src try: dst = format_file_contents(src, line_length=line_length, fast=fast, mode=mode) @@ -523,26 +524,16 @@ def format_stdin_to_stdout( return False finally: + f = io.TextIOWrapper( + sys.stdout.buffer, encoding=encoding, newline=newline, write_through=True + ) if write_back == WriteBack.YES: - f = io.TextIOWrapper( - sys.stdout.buffer, - encoding=encoding, - newline=newline, - write_through=True, - ) f.write(dst) - f.detach() elif write_back == WriteBack.DIFF: src_name = " (original)" dst_name = " (formatted)" - f = io.TextIOWrapper( - sys.stdout.buffer, - encoding=encoding, - newline=newline, - write_through=True, - ) f.write(diff(src, dst, src_name, dst_name)) - f.detach() + f.detach() def format_file_contents( @@ -603,17 +594,18 @@ def format_str( return dst_contents -def prepare_input(src: bytes) -> Tuple[str, str, str]: - """Analyze `src` and return a tuple of (newline, encoding, decoded_contents) +def decode_bytes(src: bytes) -> Tuple[FileContent, Encoding, NewLine]: + """Return a tuple of (decoded_contents, encoding, newline). - Where `newline` is either CRLF or LF, and `decoded_contents` is decoded with - universal newlines (i.e. only LF). + `newline` is either CRLF or LF but `decoded_contents` is decoded with + universal newlines (i.e. only contains LF). """ srcbuf = io.BytesIO(src) encoding, lines = tokenize.detect_encoding(srcbuf.readline) newline = "\r\n" if b"\r\n" == lines[0][-2:] else "\n" srcbuf.seek(0) - return newline, encoding, io.TextIOWrapper(srcbuf, encoding).read() + with io.TextIOWrapper(srcbuf, encoding) as tiow: + return tiow.read(), encoding, newline GRAMMARS = [ diff --git a/docs/reference/reference_functions.rst b/docs/reference/reference_functions.rst index a4f00db..3e061b8 100644 --- a/docs/reference/reference_functions.rst +++ b/docs/reference/reference_functions.rst @@ -12,12 +12,16 @@ Assertions and checks .. autofunction:: black.assert_stable +.. autofunction:: black.can_omit_invisible_parens + .. autofunction:: black.is_empty_tuple .. autofunction:: black.is_import .. autofunction:: black.is_line_short_enough +.. autofunction:: black.is_multiline_string + .. autofunction:: black.is_one_tuple .. autofunction:: black.is_python36 @@ -32,6 +36,9 @@ Assertions and checks .. autofunction:: black.is_vararg +.. autofunction:: black.is_yield + + Formatting ---------- @@ -57,12 +64,12 @@ File operations Parsing ------- +.. autofunction:: black.decode_bytes + .. autofunction:: black.lib2to3_parse .. autofunction:: black.lib2to3_unparse -.. autofunction:: black.prepare_input - Split functions --------------- @@ -102,6 +109,8 @@ Utilities .. autofunction:: black.enumerate_reversed +.. autofunction:: black.enumerate_with_length + .. autofunction:: black.generate_comments .. autofunction:: black.make_comment -- 2.39.5