* Add on_setattr hooks to attr.s and attr.ib
Signed-off-by: Hynek Schlawack <hs@ox.cx>
* Add PR newsfragment
* Fix attr.s doc sig
* Make _DisableType private
* Mark setters.frozen as NoReturn
* Rename setters.DISABLE to setters.NO_OP to clarify its purpose
DISABLE sounds less purposeful and doesn't convey its meaning as well.
* Fix type
* Loosen up type for convert even further
* Tighten type a tiny bit
* Implement auto_detect
Fixes#324
* Add test demonstrating total_ordering
* Ensure the order of applying total_ordering does not matter
* Warn if a method is missing
* Revert "Warn if a method is missing"
This reverts commit 590ef43458040e0a1b9f3644ba22b4229f7d6990.
* Add stern warning that nobody will read
* Split cmp into eq and order
Fixes#170
* Fix tests on old pypy3 versions
Old as in: currently on AP.
* Fix issue number and clarify newsfragment
* Clarify behavior and interaction between cmp/eq/order
* This sounds better
* Address Julian's review comments
* Missed a cmp
* Test the behavior of Attribute.cmp
* Make test more idiomatic
* Explain assumptions
* Clarify comment
* Grammar
* One more cmp!
* wip: support custom repr() callable for attributes
see #567
* extend ‘repr=...’ arg type in .pyi stubs
* expand docstring for attr.ib()
* add changelog entry
* add docs with example
* improve my copy/paste skills 🙈
* fix grammar
* fix typo in changelog entry
* fix and improve attrib() docstring
* detect custom repr() once, not per call. be strict about bool.
* use rst syntax, not markdown
* apply hynek's suggestions for changelog entry
* add ‘versionchanged’ note in docstring
* add custom attribute repr= to typing example
* simplify comment
Use bound type variables for iterables and mappings of the validated item types, so mypy does not erroneously require both the iterable attribute validated by deep_iterable and the item type validated by the first argument of deep_iterable to have the same type. This fixes#531.
* Implement first class exception support
Fixes#368
* Ensure single-attrib classes work too
cf https://github.com/python-attrs/attrs/pull/500#pullrequestreview-201913569
* Call into BaseException to initialiaze self.args
* Leave __str__ alone since we upcall
Based on Python pizza hallway feedback by @ambv.
* remove stray stage
* nope
* Add PEP484 stubs
* Deploy .pyi stubs alongside .py files.
This is the recommended approach for 3rd party stubs.
See: https://github.com/python/typing/issues/84#issuecomment-317217346
* Add support for the new type argument.
* Add tests for stubs and address a few issues.
* Improve declaration of private vs public objects in stubs
* More stub tests
* Separate the stub tests into their own tox env
it does not make sense to test the stubs in multiple python *runtime* environments (e.g. python 3.5, 3.6, pypy3) because the results of static analysis wrt attrs is not dependent on the runtime. Moreover, mypy is not installing correctly in pypy3 which has nothing to do with attrs.
* Update the manifest with stub files
* Remove mypy from the dev requirements
* Allow _CountingAttr to be instantiated, but not Attribute.
* Incorporate defaults into attr.ib typing
* Fix a bug with validators.and_
* Add more tests
* Remove _CountingAttr from public interface
It is crucial to ensure that make_class() works with attr.ib(), as a result we no longer have any functions that care about _CountingAttr.
* Lie about return type of Factory
this allows for an abbreviated idiom: `x: List[int] = Factory(list)`
* Add tox stubs env to travis
* used the wrong comment character in mypy tests
* Improve overloads using PyCharm order-based approach
overloads are pretty broken in mypy. the best we can do for now is target PyCharm, which is much more forgiving.
* Remove features not yet working in mypy. Document remaining issues.
* Test stubs against euresti fork of mypy with attrs plugin
Copied the pytest plugin from mypy for testing annotations: It is not an officially supported API and using the plugin from mypy could break after any update.
* Add some types and TypeVars to some types. Make tests pass
* Suppress warnings about named attribute access from fields()
e.g. fields(C).x
Eventually it would be good to add support for returning NamedTuple from the mypy plugin
* Add WIP mypy-doctest plugin
* Deal with a few remaining type issues in the docs
* sphinx doctest: don't turn warnings into errors.
doing so makes the tests abort after the first failed group.
* Update "type: ignore" comments to reflect issues fixed in mypy plugin
* doctest2: improve output formatting
* Update manifest
* static tests: use inline error declarations
* More tests
* Tests passing (with notes about remaining issues)
* Attempt to get latest plugin from euresti working
* Issues fixed.
Had to place calls to attr.ib under a class definition.
* Deal with a PyCharm bug
* Minor test improvements
* Make tests prettier
* Use 2 decorators instead of 3
* doctest2: add support for skipping mypy tests
* Add tests for inheritance, eq, and cmp
* Add fixmes and todos
* Rename convert to converter
* Attribute.validator is always a single validator
* Conform stubs to typeshed coding style
And add auto_attrib kw
* backport style fixes from typeshed
* Add test cases to cover forward references and Any
* Add fixes for forward references and Any
* Address typeshed review notes
* Use Sequence instead of List/Tuple for validator arg
list and tuple are invariant and so prevent passing subtypes of _ValidatorType
* backports changes from typeshed #1914
* backport changes from typeshed #1933
* Prevent mypy tests from getting picked up
Evidently the discovery rules changed recently for pytest.
* make our doctest extension compatible with latest sphinx
* Adjustments to the tests
* Fix flake and manifest tests (hopefully)
* Fix tests on pypy3 (hopefully)
* Update stubs from typeshed
Also update tests.
* Make PEP 561-compliant
* minor cleanup
* Consolidate stub support files into stub directory
In preparation for removing them from the pyi_stubs branch.
* Get tests passing
This is a final test of the current stubs before moving the stub tests to a new branch.
* Revert stub test additions
Replace with a simple mypy pass/fail test
* get pre-commit passing
* Address review feedback
* Move typing test up in tox envlist