comparison mercurial/revset.py @ 52640:24ee91ba9aa8

pyupgrade: drop usage of py3 aliases for `OSError` These were different classes in py2, but now a handful of error classes are just an alias of `OSError`, like `IOError`, `EnvironmentError`, `WindowsError`, etc. This is the result of running a hacked version of `pyupgrade` 3.19.1[1] $ hg files -0 'relglob:**.py' | xargs -0 \ pyupgrade --py38-plus --keep-percent-format --keep-mock --keep-runtime-typing The hack is because it doesn't have command line switches to disable most changes, so it makes tons of unrelated changes all at once. The hack is to 1) patch `pyupgrade._main._fix_tokens()` to immediately return its content arg 2) change `pyupgrade._data.register_decorator()` to only register the function if it's from the fixer we're interested in: if func.__module__ in ( "pyupgrade._plugins.exceptions", ): FUNCS[tp].append(func) return func [1] https://github.com/asottile/pyupgrade
author Matt Harbison <matt_harbison@yahoo.com>
date Sun, 05 Jan 2025 21:03:17 -0500
parents f4733654f144
children
comparison
equal deleted inserted replaced
52639:9db77d46de79 52640:24ee91ba9aa8
1370 for line in f: 1370 for line in f:
1371 n = line.strip() 1371 n = line.strip()
1372 rn = _node(repo, n) 1372 rn = _node(repo, n)
1373 if rn is not None: 1373 if rn is not None:
1374 listed_rev.add(rn) 1374 listed_rev.add(rn)
1375 except IOError as exc: 1375 except OSError as exc:
1376 m = _(b'cannot open nodes file "%s": %s') 1376 m = _(b'cannot open nodes file "%s": %s')
1377 m %= (path, encoding.strtolocal(exc.strerror)) 1377 m %= (path, encoding.strtolocal(exc.strerror))
1378 raise error.Abort(m) 1378 raise error.Abort(m)
1379 return subset & baseset(listed_rev) 1379 return subset & baseset(listed_rev)
1380 1380