else:
cache: Cache = {}
if write_back != WriteBack.DIFF:
- cache = read_cache()
+ cache = read_cache(line_length)
src = src.resolve()
if src in cache and cache[src] == get_cache_info(src):
changed = Changed.CACHED
):
changed = Changed.YES
if write_back != WriteBack.DIFF and changed is not Changed.NO:
- write_cache(cache, [src])
+ write_cache(cache, [src], line_length)
report.done(src, changed)
except Exception as exc:
report.failed(src, str(exc))
"""
cache: Cache = {}
if write_back != WriteBack.DIFF:
- cache = read_cache()
+ cache = read_cache(line_length)
sources, cached = filter_cached(cache, sources)
for src in cached:
report.done(src, Changed.CACHED)
if cancelled:
await asyncio.gather(*cancelled, loop=loop, return_exceptions=True)
if write_back != WriteBack.DIFF and formatted:
- write_cache(cache, formatted)
+ write_cache(cache, formatted, line_length)
def format_file_in_place(
CACHE_DIR = Path(user_cache_dir("black", version=__version__))
-CACHE_FILE = CACHE_DIR / "cache.pickle"
-def read_cache() -> Cache:
+def get_cache_file(line_length: int) -> Path:
+ return CACHE_DIR / f"cache.{line_length}.pickle"
+
+
+def read_cache(line_length: int) -> Cache:
"""Read the cache if it exists and is well formed.
If it is not well formed, the call to write_cache later should resolve the issue.
"""
- if not CACHE_FILE.exists():
+ cache_file = get_cache_file(line_length)
+ if not cache_file.exists():
return {}
- with CACHE_FILE.open("rb") as fobj:
+ with cache_file.open("rb") as fobj:
try:
cache: Cache = pickle.load(fobj)
except pickle.UnpicklingError:
return todo, done
-def write_cache(cache: Cache, sources: List[Path]) -> None:
+def write_cache(cache: Cache, sources: List[Path], line_length: int) -> None:
"""Update the cache file."""
+ cache_file = get_cache_file(line_length)
try:
if not CACHE_DIR.exists():
CACHE_DIR.mkdir(parents=True)
new_cache = {**cache, **{src.resolve(): get_cache_info(src) for src in sources}}
- with CACHE_FILE.open("wb") as fobj:
+ with cache_file.open("wb") as fobj:
pickle.dump(new_cache, fobj, protocol=pickle.HIGHEST_PROTOCOL)
except OSError:
pass
cache_dir = Path(workspace)
if not exists:
cache_dir = cache_dir / "new"
- cache_file = cache_dir / "cache.pkl"
- with patch("black.CACHE_DIR", cache_dir), patch("black.CACHE_FILE", cache_file):
+ with patch("black.CACHE_DIR", cache_dir):
yield cache_dir
def test_cache_broken_file(self) -> None:
with cache_dir() as workspace:
- with black.CACHE_FILE.open("w") as fobj:
+ cache_file = black.get_cache_file(black.DEFAULT_LINE_LENGTH)
+ with cache_file.open("w") as fobj:
fobj.write("this is not a pickle")
- self.assertEqual(black.read_cache(), {})
+ self.assertEqual(black.read_cache(black.DEFAULT_LINE_LENGTH), {})
src = (workspace / "test.py").resolve()
with src.open("w") as fobj:
fobj.write("print('hello')")
result = CliRunner().invoke(black.main, [str(src)])
self.assertEqual(result.exit_code, 0)
- cache = black.read_cache()
+ cache = black.read_cache(black.DEFAULT_LINE_LENGTH)
self.assertIn(src, cache)
def test_cache_single_file_already_cached(self) -> None:
src = (workspace / "test.py").resolve()
with src.open("w") as fobj:
fobj.write("print('hello')")
- black.write_cache({}, [src])
+ black.write_cache({}, [src], black.DEFAULT_LINE_LENGTH)
result = CliRunner().invoke(black.main, [str(src)])
self.assertEqual(result.exit_code, 0)
with src.open("r") as fobj:
two = (workspace / "two.py").resolve()
with two.open("w") as fobj:
fobj.write("print('hello')")
- black.write_cache({}, [one])
+ black.write_cache({}, [one], black.DEFAULT_LINE_LENGTH)
result = CliRunner().invoke(black.main, [str(workspace)])
self.assertEqual(result.exit_code, 0)
with one.open("r") as fobj:
self.assertEqual(fobj.read(), "print('hello')")
with two.open("r") as fobj:
self.assertEqual(fobj.read(), 'print("hello")\n')
- cache = black.read_cache()
+ cache = black.read_cache(black.DEFAULT_LINE_LENGTH)
self.assertIn(one, cache)
self.assertIn(two, cache)
fobj.write("print('hello')")
result = CliRunner().invoke(black.main, [str(src), "--diff"])
self.assertEqual(result.exit_code, 0)
- self.assertFalse(black.CACHE_FILE.exists())
+ cache_file = black.get_cache_file(black.DEFAULT_LINE_LENGTH)
+ self.assertFalse(cache_file.exists())
def test_no_cache_when_stdin(self) -> None:
with cache_dir():
result = CliRunner().invoke(black.main, ["-"], input="print('hello')")
self.assertEqual(result.exit_code, 0)
- self.assertFalse(black.CACHE_FILE.exists())
+ cache_file = black.get_cache_file(black.DEFAULT_LINE_LENGTH)
+ self.assertFalse(cache_file.exists())
def test_read_cache_no_cachefile(self) -> None:
with cache_dir():
- self.assertEqual(black.read_cache(), {})
+ self.assertEqual(black.read_cache(black.DEFAULT_LINE_LENGTH), {})
def test_write_cache_read_cache(self) -> None:
with cache_dir() as workspace:
src = (workspace / "test.py").resolve()
src.touch()
- black.write_cache({}, [src])
- cache = black.read_cache()
+ black.write_cache({}, [src], black.DEFAULT_LINE_LENGTH)
+ cache = black.read_cache(black.DEFAULT_LINE_LENGTH)
self.assertIn(src, cache)
self.assertEqual(cache[src], black.get_cache_info(src))
def test_write_cache_creates_directory_if_needed(self) -> None:
with cache_dir(exists=False) as workspace:
self.assertFalse(workspace.exists())
- black.write_cache({}, [])
+ black.write_cache({}, [], black.DEFAULT_LINE_LENGTH)
self.assertTrue(workspace.exists())
@event_loop(close=False)
fobj.write('print("hello")\n')
result = CliRunner().invoke(black.main, [str(workspace)])
self.assertEqual(result.exit_code, 123)
- cache = black.read_cache()
+ cache = black.read_cache(black.DEFAULT_LINE_LENGTH)
self.assertNotIn(failing, cache)
self.assertIn(clean, cache)
def test_write_cache_write_fail(self) -> None:
with cache_dir(), patch.object(Path, "open") as mock:
mock.side_effect = OSError
- black.write_cache({}, [])
+ black.write_cache({}, [], black.DEFAULT_LINE_LENGTH)
def test_check_diff_use_together(self) -> None:
with cache_dir():
)
self.assertEqual(result.exit_code, 1)
+ def test_read_cache_line_lengths(self) -> None:
+ with cache_dir() as workspace:
+ path = (workspace / "file.py").resolve()
+ path.touch()
+ black.write_cache({}, [path], 1)
+ one = black.read_cache(1)
+ self.assertIn(path, one)
+ two = black.read_cache(2)
+ self.assertNotIn(path, two)
+
if __name__ == "__main__":
unittest.main()